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WEITERES VORGEHEN slehe Punkte 1 und 4 unten 


Internationales Aktenzeichen 

PCT/DE 99/02753 


Internationales Anmeldedatum 
(Tag/Momt/Jahr) 01/09/1999 


Anmetder 

SIEMENS AKTIENGESELLSCHAFT et al . 



1. [J] Dem Anmelder wtrd mftgetellt, daB der Internationale Rechefchenberlcht eretelft wurde und Ihm hiermlt ubermfttelt wird. 
Einrekshung von Anderungen und einer Ertdftrung nach Artitol 19: 

Der Anmelder karm auf eigetwn Wunsch die Anepruche der intemationalen Anmeldurtg andem (atehe Re^el 46): 

Bis wann sind Anderungen •inzureichen? 

Die Frist zur ElnrelchunQ solcher Anderungen betrfigt QbUcherwelae zwel Monate ab der Obermttttung des 
IntematlonaJen Rechercftenbertchts; wettere Elnzethetten sind den Anmerkungen auf dem Betbtatt zu entnehmea 

Wo sind Anderungen einzureichen? 

Unmfttetoar betm IntematlonaJen Buro der WIPO, 34. CHEMIN des Colombettee, CH-121 1 Gent 20, 
Telefaxnr.: (41-22) 740.14.35 

Nflhers Hin 



sind den Anmerkungen auf dem Belblatt zu entnehmea 

2. I 1 Dem Anmelder wtrd mftgetellt, daB keJn (ntemationaler Rechercnenberlcrrt ereteBt wlrd und dafl thm hiermit die Erklarung nach 
— Artikel 17(2)a) uberrnJttelt wlrd. 

3. I I Hinsichtlich des Widerspruchs gegen die Entrtcrrtung einer zusatzilchen Gebuhr (zuaatzJicher Gebuhren) nach Regel 40.2 wlrd 
< — I dem Anmelder mftgetellt daB 

□ der Wlderapruch und die Entacheldung hleruber zusammen mtt seinem Antrag auf ObermltUung des Wortlauts sowohl des 
WMersprucha ate audi der Entscheldung hleruber an die Bestlmmungsamter dem IntematlonaJen Buro Qbermittelt worden 
sind. 

□ noch kelne Entscheldung uber den Wlderapruch voriiegt; der Anmelder wird benachrtchtigt, sobald etne Entscheldung 
getroffen wurde. 

4. WeitBrss Vorgehen: Der Anmelder wird auf folgendes aufmerksam gemacht 

Kurz nach Ablaut von 18 Monaten sett dem Prlorftatsdatum wlrd die internatlonaJe Anmeldung vom IntematlonaJen Buro wroftent- 
lichL Winder Anmelder die Veroffentlichung verhbidem oder auf einen spateren ZeHpunkt verschiebea so muB gem&B Regel 90 ^1 
bzw. 9Crr3 vor AbschluB der techrdschen Vorbereltungen fur die Internationale Veroffentlichung eine ErkJarung uber die ZurOcfcnah- 
me der IntematlonaJen Anmeldung oder des Priorltatsanapruohs beim Intemationalen Buro etngehen. 

InnerhaJb von 19 Monaten sett dem Priorttatsdatum 1st efn Antrag auf Internationale voriauflge Prufuna etnzurelchen, wenn der 
Anmelder den Eintrftt In die nationale Phase bis zu 30 Monaten sett dem Priorttatsdatum (In manchen Amtem sogar noch langer) 
verschteben mdchte. 

Irtnemalb von 20 Monaten sett dem Priorttatsdatum muB der Anmelder die fur den Eirrtrttt In die nationale Phase vorgeschrlebenen 
Handtungen vor alien Beetimmungsamtem vomehmen, die nlcht innerhalb von 1 9 Monaten sett dem Priorttatsdatum In der 
Anmeldung oder etner nachtragJlchen Auswahteridaiung auegewahlt wurden oder nlcht ausgewahtt werden konnten, da fur ale 
Kapttel ll des Vertmges nlcht verbindDch 1st 



Name und Postanschrift der IntematlonaJen Recherchenbehorde 

Europalsches Paterttamt, P.B. 5818 PatenHaan 2 
NL-2280 HV RljswQk 

Tel. (+31-70) 340-2040, Tx. 31 651 epo nl, 
Fax: (+31-70) 340-3016 



Bevollmachtigter Bedlensteter 

Luda Van Plnxteren 



Formbtatt PCT/ISA/220 (Jiril 1 998) 



(Slehe Anmerkungen aulBeblatt) 



^^ERKUNGEN ZU FORMBLATT PCT/I^^2( 



Diese Anmerkungen sollen grundlegende Hinweise zur Einreichung von Anderungen gem a (3 Artikel 19 geben. Dieaen Anmerkungen 
liegen die Erforderntsse des Vert rags Gber die internationals Zusammenarbeit auf dem Gebiet des Patentwesens (PCT), der Ausfuhrungs- 
ordnung und der Verwattungsrichtlinien zu dtesem Vertrag 2ugrunde. Bei Abweichungen zwischen cfiesen Anmerkungen und 
obengenannten Texten sind letztere maftgebend. Nahere Einzelheiten sind dem PCT-Lettfaden fur Anmelder, einer Veroffentlichung der 
WIPO, zj entnehmen. 

Die in dies on Anmerkungen verwendeten Begriffe "Artikel", "Regel" und "Abschnitt" beziehen sich jeweils auf die Bestimmungen des 
PCT-Vertrags, der PCT-Ausfuhrungsordnung bzw. der PCT-VerwaJtungsrichtlinien. 



hinweise zu Anderungen gemAss artikel 19 



Nach Erhatt des intemationaJen Recherchenberichts hat der Anmelder die Moglichkeit, einmal die Anspruche der intemationaJen 
Anmeldung zu an dem Ea tat jedoch zu betonen, daG, da alle Teile der intern at ionalen Anmeldung (Anspruche, Beschretbung und 
Zeichnungen) wan rend des intemationaJen vorlaufigen Prufungsverfahrens geandert warden kfinnen, normaJerweise keine Notwendtgkeit 
bests ht, Anderungen der Anspruche nach Artikel 19 einzureichen, auBer wenn der Anmelder zB. zum Z we eke eines vorlaufigen 
Schutzes die Veroffentlichung diese r Anspruche wQnscht oder ein anderer Grund fQr eine An de rung der Anspruche vor ihrer international 
len Veroffentlichung vortiegt. Weiterhin est zu beachten, daft ein vorlauftger Schutz nur in einigen Staaten erhaitlich ist. 



Welche Telle der IntemationaJen Anmeldung konnen geandert werden? 

Im Rahmen von Artikel 19 kflnnen nur die Anspruche geandert werden. 

In der intemationalen Phase kdnnen die Anspruche auch nach Artikel 34 vor der mit der intern at ionalen vorlaufigen PrOfung be auf - 
tragten Be horde geandert (oder nochmals geandert) werden. Die Beschreibung und die Zeichnungen kdnnen nur nach Artikel 34 
vor der mit der intemationaJen vorlaufigen Prufung beauftragten Behdrde geandert werden. 

Beim Eintrrtt in die nation aJe Phase kdnnen alle Teile der intemationaJen Anmeldung nach Artikel 28 oder gegebenenfalls Artikel 
41 geandert werden. 



Bis wann sind Anderungen einzureichen? 

InnerhaJb von zwet Monaten ab der Ubermrttlung des intern ati on alen Recherchenberichts oder innerrtalb von sechzehn Monaten ab 
dem Pnontatsdatum, je nach dem, welche Fnst apdter ablauft Die Anderungen getten jedoch als rechtzeitig eingereicht, wenn oie 
dem IntemationaJen BQro nach AbJauf der maftgebenden Frist, aber noch vor AbschluB der tech ni ache n Vorbereitungen fOr die 
intemattonaJe Veroffentlichung {Regel 46.1) zugehen. 

Wo sind die Anderungen nicht einzureichen? 

Die Anderungen konnen nur beim IntemationaJen Buro, nicht aber beim Anmeldeamt oder der Intemationalen Recherchenbehdrde 
eingereicht werden (Regel 46.2). 

Falls ein Ant rag auf international© voriaufige PrOfung eingereicht wurde/wird, siehe unten. 



In welcher Form kdnnen Anderungen erfolgen? 

Eine Anderung kann erfolgen durch Streichung eines oder mehrerer ganzer Anspruche, durch HinzufQgung eines oder mehrerer 
neuer Anspruche oder durch Anderung des Wortlauts eines oder mehrerer Anspruche in der eingereicht en Faasung. 

FQr jedes AnspruchsbJatt, das sich auf grund einer oder mehrerer Anderungen von dem ursprunglich eingereichten Blatt 
unterscheidet, ist ein Ersatzblatt einzureichen. 

AJIe Anspruche, die auf einem Ersalzbfatt erscheinen, sind mit arabischen Ziffem zu numerieren. Wrrd ein Anspruch gestrichen, so 
brauchen, die anderen AnsprOche nicht neu numeriert zu werden. Im Fall einer Neunumerierung sind die Anspruche fortlaufend zu 
numerieren (VerwaJtungshchtlinien, Abschnitt 205 b)). 

Die Anderungen sind In der Sprache abzufassen, In der dfeintematlonale Anmeldung veroffentllcht wlrd. 



Welche Unterlagen sind den Anderungen beizufGgen? 
Beglettschreiben (Abschnitt 205 b)): 

Die Anderungen sind mit einem Begleitachreiben einzureichen. 

Das Beglertschreiben wird nicht zusammen mit der intemationaJen Anmeldung und den geanderten Anspruch en verdffentlicht. Es 
ist nicht zu verwechseln mit der "Erktarung nach Artikel 19(1)' (siehe unten, "Erklarung nach Artikel 1 9 (1 )*). 

Das Beglettschreiben Ist nach Wahl des An meld era In engllscher oder franzdslscher Sprache abzufassen. Bei engllschspra- 
chlgen Intemationalen Anmeldungen 1st das Beglettschreiben aber ebenfalls In engllscher, bet tranzoslschsprachlgen Inter- 
nattonalen Anmeidungen in franzdslscher Sprache abzufassen. 
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ANM^^NGEN ZU FORMBLATT PCT/ISA/220^^tsetzung) 



lm Begleitschreiben sind die Unterschiede zwischen den Anspruchen in der eingereichten Fassung und den geanderten AnsprOchen 
anzugeben. So tat insbesondere zu jedem Anspruch in der irrtemationalen Anmeldung anzugeben (gteichlautende Angaben zu 
verschiedenen Anspruchen konnen zusammengefaftt warden), ob 

i) der Anspruch unverandert ist; 

it) der Anspruch gestrichen worden ist; 

iii) der Anspruch neu ist; 

rv) der Anspruch einen oder mehrere AnsprOche in der eingereichten Fassung ersetzt; 

v) der Anspruch auf die Teilung etnes Anspruchs in der eingeretchten Fassung zurOokzufuhren ist. 



Im folgenden sind Belsplele angegeben, wle Anderungen im Begleltachreiben zu erilutem sind: 

1. fWenn anatelle von ursprOnglich 48 Anspruchen nach der An de rung einiger AnsprOche 51 AnsprOche existieren]: 

"Die AnsprOche 1 bis 29, 31, 32, 34, 35, 37 bis 48 warden durch geanderte AnsprOche gieicher Numeric rung ersetzt; AnsprOche 
30, 33 und 36 unverandert; neue AnsprOche 49 bis 51 hinzugefugt." 

2. [Wenn anstelte von ursprOnglich 15 Anspruchen nach der And© rung alter AnsprOche 1 1 AnsprOche existieren]: 
"Geanderte AnsprOche 1 bis 1 1 treten an die Stelle der AnsprOche 1 bis 1 5 " 

3. [Wenn ursprOnglich 1 4 AnsprOche existierten und die Anderungen darin bestehen, da 3 einige AnsprOche gestrichen warden und 
neue AnsprOche htnzugefOgt werden]: 

AnsprOche 1 bis 6 und 14 unverandert; AnsprOche 7 bis 13 gestrichen; neue AnsprOche 15, 16 und 1 7 hinzugefugt. "Oder" An- 
sprOche 7 bis 13 gestrichen; neue AnsprOche 15, 16 und 17 hinzugefugt; atle Obrigen AnsprOche unverandert." 

4. [Wenn verechiedene Arten von Anderungen durchgefOhrt werden}: 

'AnsprOche 1-10 unverandert; AnsprOche 1 1 bis 13, 18 und 19 gestrichen; AnsprOche 14, 15 und 16 durch geanderten An- 
spruch 14 ersetzt; Anspruch 1 7 in geanderte AnsprOche 15, 16 und 17 unterteilt; neue AnsprOche 20 und 21 hinzugefOgt." 

"Erklarung nach Artikel 19(1)" (Reg©* 46.4) 

Den Anderungen kann erne Erklarung beigefGgt werden, mrt der die Anderungen eriautert und ihre Auswirkungen auf die 
Beschreibung und die Zeichnungen dargeiegt werden (die nicht nach Artikel 19(1) geandert werden konnen). 

Oie Erklarung wird zusammen mrt der intemabonalen Anmeldung und den geanderten Anspruchen verdffentlicht. 
Sie 1st In der Sprache abzufassen, tn der die International en Anmeldung verdffentlicht wind. 

Sie mufi kurz gehaJten sein und darf, wenn in englischer Sprache abgefaBt oder ins Englische Obersetzt, nicht mehr ajs 500 
Wdrter umfassen 

Oie Erklarung ist nicht zu verwechseln mit dem Begleitschreiben, das auf die Unterschiede zwischen den AnsprOchen in der 
eingereichten Fassung und den geanderten Anspnjchen Nnweist, und' ersetzt letzteres nicht. Sie ist auf einem gesonderten Blatt 
einzureichen und in der Oberschrift als solche zu kennzeichnen, vorzugsweise mit den Wort on "Erklarung nach Artikel 19 (1)". 

Die Erklarung darf keine herabsetzenden Au Rerun gen Oberden inter nationalen Recherchenbericht oder die Bedeutung von in dem 
Bericht angefOhrten Verdfferrttichungen enthaiten. Sie darf auf im intern ationaJen Recherchenbericht angefOhrte verdffentlichun- 
gen, die sich auf einen bestimmten Anspruch beziehen, nur im Zusammenhang mit einer Anderung dieses Anspruchs Bezug 
nehmen. 



Auswirkungen etnes beretta gestellten Ant rags auf International evorlaunge PrOfung 

1st zum Zeitpunkt der Einreichung von Anderungen nach Artikel 19 bereits ein Arrtrag auf intemationale vorlaufige PrOfung 
gestellt worden, so sollte der Anmelder in seinem InterBase gleichzeitig mit der Einreichung der Anderungen beim Intern at ion alen 
BOro auch eine Kopie der Anderungen bei der mit der intemationalen vortaufigen PrOfung beauftragen Behdrde einreichen (siehe 
Regel 62.2 a), erster Satz). 



Auswirkungen von Anderungen hlnslchtllch der Obersetzung derintemationalen Anmeldung beim Eintrttt In die 
nation ale Phase 

Der Anmelder wird darauf hingewiesen, daO bei Eirrtntt in die nationals Phase mftglicherweise an start oder zusatzlich zu der Ober- 
setzung der AnsprOche in der eingereichten Fassung eine Obersetzung der nach Artikel 19 geanderten AnsprOche an die 
bestimmten/ausgewahtten Amter zu Gbermitteln ist. 

Nahere Einzelheiten Qber die Ertordemisse jedes bestimmten/ausgewahtten Amts sind Band II des PCT-Leitfadens fOr Anmelder 
zu errt nehmen. 
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THIS 




TOE A 



z 



PATENT COOPERATION m£ATY 

PCT 

INTERNATIONAL PRELIMINARY EXAMINATION REPORT 

(PCT Article 36 and Rule 70) 



Applicant's or agent's file reference 
GR 98P2477P 


ey-it> ci nxuro a rT i n v See Notification of Transmittal of International 
FOR FURTHER ACTION Pre i iminary Examination Report (Form PCT/I PEA/4 16) 


International application No. 


International filing date {day/month/year) 


Priority date (day/month/year) 


PCT/DE99/02753 


01 September 1999(01.09.99) 


02 September 1998 (02.09.98) 


International Patent Classification (IPC) or national classification and IPC 




G06F 17/50 






Applicant 

SIEMENS AKTIENGESELLSCHAFT 



1. This international preliminary examination report has been prepared by this International Preliminary Examining 
Authority and is transmitted to the applicant according to Article 36. 



2. This REPORT consists of a total of 



sheets, including this cover sheet. 



This report is also accompanied by ANNEXES, i.e., sheets of the description, claims and/or drawings which have 
been amended and are the basis for this report and/or sheets containing rectifications made before this Authority 
(see Rule 70. 16 and Section 607 of the Administrative Instructions under the PCT). 



These annexes consist of a total of 



sheets. 



rtE OFIVED 



This report contains indications relating to the following items 
Basis of the report 
Priority 



I 




II 


□ 


III 


□ 


IV 


□ 


V 




VI 


□ 


VII 


El 


VIII 


X 



«** 1 9 Z001 



TO 3600 MAIL ROOM 

Non-establishment of opinion with regard to novelty, inventive step and industrial applicability 
Lack of unity of invention 

Reasoned statement under Article 35(2) with regard to novelty, inventive step or industrial applicability; 
citations and explanations supporting such statement 



Certain documents cited 

Certain defects in the international application 

Certain observations on the international application 



RECEIVED 

JUL 0 9 2001 
Technology Center 21 00 



Date of submission of the demand 

07 March 2000 (07.03.00) 


Date of completion of this report 

05 December 2000 (05.12.2000) 


Name and mailing address of the IPEA/EP 
Facsimile No. 


Authorized officer 
Telephone No. 



Form PCT/IPEA/409 (cover sheet) (January 1994) 




INTERNATIONAL PRELIMINARY EXAMINATION REPORT 



International application No. 

PCT/DE99/02753 



I. Basis of the report 



1 . This report has been drawn on the basis of {Replacement sheets which have been furnished to the receiving Office in response to an imitation 
under Article 14 are referred to in this report as "originally filed" and are not annexed to the report since they do not contain amendments.); 

| | the international application as originally filed. 

the description, pages 1- 32 , as originally filed, 

pages _, filed with the demand, 

pages , filed with the letter of 

pages , filed with the letter of . 



^ the claims, 



Nos. 
Nos. 
Nos. 
Nos. 
Nos. 



1-14 



, as originally filed, 

, as amended under Article 19, 

, filed with the demand, 

, filed with the letter of 19 September 2000 (19.09.2000) 
, filed with the letter of 



the drawings, sheets/fig 
sheets/fig 
sheets/fig 
sheets/fig 



1-5 



as originally filed, 
filed with the demand, 
filed with the letter of 
filed with the letter of 



2. The amendments have resulted in the cancellation of: 

□ the description, pages 

I ) the claims. Nos. 



I 1 the drawings, sheets/fig 



2 I 1 This report has been established as if (some of) the amendments had not been made, since they have been considered 
— to go beyond the disclosure as filed, as indicated in the Supplemental Box (Rule 70.2(c)). 



4. Additional observations, if necessary: 
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INTERNATIONAL PRELIMINARY EXAMINATION REPORT 



International application No. 
PCT/DE 99/02753 



V. Reasoned statement under Article 35(2) with regard to novelty, inventive step or industrial applicability; 
citations and explanations supporting such statement 



1. 


Statement 












Novelty (N) 


Claims 




3, 9, 


11, 14 YES 






Claims 


1- 


2, 4-8, 


10, 12-13 NO 




Inventive step (IS) 


Claims 






YES 




Claims 




3, 9, 


11, 14 NO 




Industrial applicability (IA) 


Claims 




1- 


-14 YES 




Claims 






NO 


2. 


Citations and explanations 












1. This report 


makes reference 


to the 


following 




document : 












Dl: US-A- 


5 691 912 


( DUNCAN 


ROBERT 


G. ) , 25 November 



2 . 



2. 1 



2.2 



1997. 

The subject matter of independent Claims 1 and 6 is 

not novel for the following reasons: 

Dl already shows a method which corresponds to the 
method as per Claim 1 and in which two different 
data files (40, 45) can be used in order to describe 
digital circuits graphically. A "Schematic Editor" 
is used for that purpose to create either a 
"schematic diagram" or a "state flow diagram" (Fig. 
5; column 7, line 12 - column 9, line 10) . 

The method of Dl naturally also allows only one of 
the two representation forms to be selected, that is 
either a state flow diagram or only a schematic 
diagram . 

The device as per Claim 6 is also already known from 
Dl . The means used correspond to the method steps in 
Claim 1, and therefore the same arguments apply. 
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INTERNATIONAL PRELIMINARY EXAMINATION REPORT 



international application No. 
PCT/DE 99/02753 



3V The following observations apply to the dependent 
claims : 

3.1 The features of Claims 2, 7, 8, 12 and 13 are not 
novel over Dl either, since that document describes 
digital circuits (see above) . 

3.2 The features of Claim 4 are also known from Dl, 
since that document uses corresponding graphic 
elements (see, e.g., Fig. 4). 

3.3 Even if Claim 5 were supported by the description 
(see Box VIII), its features are known from Dl, 
since the structural rules are checked in that 
document at the latest during netlist generation 
(see, e.g., column 9, lines 4-9). 

3.4 The device as per Claim 10 is also already known 
from Dl . The only difference from the device as per 
Claim 6 is that the two data files (40, 45) are 
accommodated in another "substructure" than the rest 
of the system. However, this very general wording 
can be easily deduced from the system shown in Dl 
(see, e.g., Fig . 5 ) . 

3.5 Dependent Claims 3, 9, 11 and 14 do not contain any 
features which, in combination with the features of 
any claim to which they refer, meet the PCT 
requirement for inventive step, for the following 
reasons : 

3.5.1 Claims 3, 9 and 14: Expanding the system of Dl for 
describing a technical installation is an obvious 
procedure to a person skilled in the art. 

3.5.2 Claim 11: Coupling various devices by communications 
networks is also an obvious measure. 



Form PCT/I PEA/409 (Box V) (January 1994) 




INTERNATIONAL PRELIMINARY EXAMINATION REPORT 



rnational application No. 
PCT/DE 99/02753 




The following defects in the form or contents of the international application have been noted: 



1. The independent claims have not been drafted in the 
two-part form defined by PCT Rule 6.3(b). However, 
the two-part form would appear to be appropriate in 
this case. Accordingly, the features known in 
combination from the prior art (document Dl) should 
be set out in a preamble (PCT Rule 6.3(b) (i)) and 
the remaining features should be specified in a 
characterising part (PCT Rule 6.3(b) (ii) ) . 

2. Contrary to PCT Rule 5.1(a) (ii), the description 
does not cite document Dl and does not indicate the 
relevant prior art disclosed therein. 



Form PCT/IPEA/409 (Box VII) (January 1994) 



» w * ' . ^Pjernational application No. 

INTERNATIONAL PRELIMINARY EXAMINATION REPORT PCT/DE 99/02753 



VIII. Certain observations on the international application 

I*he following observations on the clarity of the claims, description, and drawings or on the question whether the claims are fully 
supported by the description, are made: 

1. The description does not mention the features of 
Claim 5. Contrary to PCT Article 6, this claim is 
therefore not supported by the description. 
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VERTRAG UBE 




IE INTERNATIONALE ZUSJftM 



GEBIET DES PATENTWE! 



ENARBEIT AUF DEM 
S 



PCT 

INTERNATIONALER VORLAUFIGER PRUFUN G^jEfcn i GHT — 

(Artikel 36 und Regel 70 PCT) 



Aktenzeichen des Anmelders Oder Anwalts 
GR 98P2477P 



WE1TERES VORGEHEN 



siehe Mitteilung uber die Ubersendung des intemationalen 
vorlaufigen Prufungsbericht (Formblatt PCT/IPEA/416) 



Internationales Aktenzeichen 
PCT/DE99/02753 



Internationales Anmeldedatumrr ag/Monat/Jahr) 
01/09/1999 



Prioritatsdatum (Tag/Monat/Tag) 
02/09/1998 



Internationale Patentklassification (IPK) Oder nationale Klassifikation und IPK 
G06F17/50 



Anmelder 

SIEMENS AKTIENGESELLSCHAFT et al. 



1 . Dieser internationale vorlaufige Prufungsbericht wurde von der mit der internationale vorlaufigen Prufung beauftragte 
Behorde erstellt und wird dem Anmelder gemaB Artikel 36 ubermittelt. 

2. Dieser BERICHT umfaBt insgesamt 6 Blatter einschlieBlich dieses Deckblatts. 

St AuBerdem liegen dem Bericht ANLAGEN bei; dabei handelt es sich urn Blatter mit Beschreibungen, Anspruchen 
und/oder Zeichnungen, die geandert wurden und diesem Bericht zugrunde liegen, und/oder Blatter mit vor dieser 
Behorde vorgenommenen Berichtigungen (siehe Regel 70.16 und Abschnitt 607 der Verwaltungsrichtlinien zum PCT). 

Diese Anlagen umfassen insgesamt 3 Blatter. 



3. Dieser Bericht enthalt Angaben zu folgenden Punkten: 



Grundlage des Berichts 
Prioritat 

Keine Erstellung eines Gutachtens uber Neuheit, erfinderische Tatigkeit und gewerbliche Anwendbarkeit 
Mangelnde Einheitlichkeit der Erfindung 

Begrundete Feststellung nach Artikel 35(2) hinsichtlich der Neuheit, der erfinderische Tatigkeit und der 
gewerbliche Anwendbarkeit; Unterlagen und Erklarungen zur Stutzung dieser Feststellung 

Bestimmte angefuhrte Unterlagen 

Bestimmte Mangel der intemationalen Anmeldung 

Bestimmte Bemerkungen zur intemationalen Anmeldung 



I 




II 


□ 


III 


□ 


IV 


□ 


V 




VI 


□ 


VII 




VIII 





Datum der Einreichung des Antrags 
07/03/2000 



Name und Postanschrift der mit der intemationalen vorlaufigen 
Prufung beauftragten Behorde: 
Europaisches Patentamt 

D-80298 Munchen 
Tel. +49 89 2399 - 0 Tx: 523656 epmu d 

Fax: +49 89 2399 - 4465 



Datum der Fertigstellung dieses Berichts 
05.12.2000 



Bevollmachtigter Bediensteter 
Amann, R 

Tel. Nr. +49 89 2399 2298 



Formblatt PCT/I PEA/409 (Deckblatt) (Januar 1994) 
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INTERNATIONALER VORLAUFIGER 
PRUFUNGSBERICHT 



Internationales Aktenzeichen PCT/DE99/02753 



I. Grundlage des Berichts 

1 Dieser Bericht wurde erstellt auf der Grundlage (Ersatzblatter, die dem Anmeldeamt auf eine Aufforderung nach 
Artikef 14 hin vorgelegt wurden, gelten im Rahmen dieses Berichts als "ursprunglich eingereicht" und sind ihm 
nicht beigefugt, weil sie keine Anderungen enthaften.): 
Beschreibung, Seiten: 

1-32 ursprungliche Fassung 

Patentanspruche, Nr.: 

1-14 eingegangen am 20/09/2000 mit Schreiben vom 19/09/2000 

Zeichnungen, Blatter: 

1-5 ursprungliche Fassung 



2. Hinsichtlich der Sprache: Alle vorstehend genannten Bestandteile standen der Behorde in der Sprache, in der 
die internationale Anmeldung eingereicht worden ist, zur Verfugung oder wurden in dieser eingereicht, sofem 
unter diesem Punkt nichts anderes angegeben ist. 

Die Bestandteile standen Behorde in der Sprache: , zur Verfugung bzw. wurden in dieser Sprache eingereicht; 
dabei handelt es sich um 

□ die Sprache der Ubersetzung, die fur die Zwecke der international en Recherche eingereicht worden ist (nach 
Regel 23.1(b)). 

□ die Veroffentlichungssprache der internationalen Anmeldung (nach Regel 48.3(b)). 

□ die Sprache der Ubersetzung, die fur die Zwecke der internationalen vorlaufigen Prufung eingereicht worden 
ist (nach Regel 55.2 und/oder 55.3). 

3. Hinsichtlich der in der internationalen Anmeldung offenbarten Nucleotid- und/oder Aminosauresequenz ist die 
internationale vorlaufige Prufung auf der Grundlage des Sequenzprotokolls durchgefuhrt worden, das: 

□ in der internationalen Anmeldung in schriftlicher Form enthalten ist. 

□ zusammen mit der internationalen Anmeldung in computerlesbarer Form eingereicht worden ist. 

□ bet der Behorde nachtraglich in schriftlicher Form eingereicht worden ist. 

□ bei der Behorde nachtraglich in computerlesbarer Form eingereicht worden ist. 

□ Die Erklarung, dass das nachtraglich eingereichte schriftliche Sequenzprotokoll nicht uber den 
Offenbarungsgehalt der internationalen Anmeldung im Anmeldezeitpunkt hinausgeht, wurde vorgelegt. 

□ Die Erklarung, dass die in computerlesbarer Form erfassten Informationen dem schriftlichen 
Sequenzprotokoll entsprechen, wurde vorgelegt. 

4. Aufgrund der Anderungen sind folgende Unterlagen fortgefallen: 



Formblatt PCT/1 PEA/409 (Felder l-VIII, Blatt 1) (Januar 1994) 



INTERNATIONALER VORLAUFIGER 
PRUFUNGSBERICHT 



Internationales Aktenzeichen PCT/DE99/02753 



□ Beschreibung, Seiten: 

□ Anspruche, Nr.: 

□ Zeichnungen, Blatt: 

5. □ Dieser Bericht ist ohne Berucksichtigung (von einigen) der Anderungen erstellt worden, da diese aus den 
angegebenen Grunden nach Auffassung der Behorde uber den Offenbarungsgehalt in der ursprunglich 
eingereichten Fassung hinausgehen (Regel 70.2(c)). 

(Auf Ersatzblatter, die solche Anderungen enthalten, ist unter Punkt 1 hinzuweisen;sie sind diesem Bericht 
beizufugen). 



6. Etwaige zusatzliche Bemerkungen: 



V. Begrundete Feststellung nach Artikel 35(2) hinsichtlich der Neuheit, der erfinderischen Tatigkeit und der 
gewerblichen Anwendbarkeit; Untertagen und Erklarungen zur Stutzung dieser Feststellung 

1. Feststellung 

Neuheit (N) Ja: Anspruche 3,9,11,14 

Nein: Anspruche 1-2, 4-8, 10, 12-13 

Erfinderische Tatigkeit (ET) Ja: Anspruche 

Nein: Anspruche 3,9,11,14 

Gewerbliche Anwendbarkeit (GA) Ja: Anspruche 1-14 

Nein: Anspruche 



2. Unterlagen und Erklarungen 
siehe Beiblatt 



VII. Bestimmte Mangel der internationalen Anmeldung 

Es wurde festgestellt, da(3 die internationale Anmeldung nach Form oder Inhalt folgende Mangel aufweist: 
siehe Beiblatt 



VIII. Bestimmte Bemerkungen zur internationalen Anmeldung 

Zur Klarheit der Patentanspriiche, der Beschreibung und der Zeichnungen oder zu der Frage, ob die Anspruche 
in vollem Umfang durch die Beschreibung gestutzt werden, ist folgendes zu bemerken: 
siehe Beiblatt 



Fomiblatt PCT/I PEA/409 (Felder l-VIII, Blatt 2) (Januar 1994) 
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INTERNATIONALER VORLAUFIGER Internationales Aktenzeichen PCT/DE99/02753 
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Zu Punkt V 

Begrundete Feststellung nach Regel 66.2(a)(ii) hinsichtlich der Neuheit, der 
erfinderischen Tatigkeit und der gewerblichen Anwendbarkeit; Unterlagen und 
Erklarungen zur Stutzung dieser Feststellung 

1 . Es wird auf das folgende Dokument verwiesen: 

D1 : US 5 691 91 2 A (DUNCAN ROBERT G) 25. November 1 997 



2. Der Gegenstand der unabhangigen Anspruche 1, und 6 ist aus den 

nachfolgenden Grunden nicht neu: 

2.1 Betreffend Anspruch 1 zeigt Dokument D1 bereits ein entsprechendes Verfahren, 
bei dem zwei unterschiedliche Dateien (40, 45) verwendet werden konnen, urn 
Digitalschaltungen grafisch zu beschreiben. Dazu wird ein "Schematic Editor" 
verwendet, mit dem entweder ein "schematic diagram" oder ein "state flow 
diagram" erstellt werden kann (fig. 5; Spalte 7, Zeile 12 bis Spalte 9, Zeile 10). 

Naturlich ermoglicht das Verfahren nach D1 auch die Auswahl nur einer der 
beiden Darstellungsformen, also nur ein Flussdiagramm oder nur ein 
schematisches Diagramm konnen dargestellt werden. 

2.2 Die Anordnung nach Anspruch 6 ist ebenfalls bereits aus D1 bekannt. Die 
verwendeten Mittel entsprechen den Verfahrensschritten aus Anspruch 1 , so daB 
die dortige Begrundung entsprechend gilt. 

3. Was die abhangigen Anspruche betrifft, so gilt das Folgende: 

3.1 Die Merkmale der Anspruche 2, 7, 8, 12 und 13 sind im Hinblick auf D1 ebenfalls 
nicht neu, da dort Digitalschaltungen beschrieben werden (s.o.). 

3.2 Die Merkmale des Anspruchs 4 sind ebenfalls aus D1 bekannt, da dort 
entsprechende Graphenelemente verwendet werden (siehe z.B. Figur 4). 
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3.3 Selbst wenn Anspruch 5 durch die Beschreibung gestutzt ware (siehe unten), so 
sind seine Merkmale doch aus D1 bekannt, da dort spatestens bei der Netzlisten- 
generierung die Strukturregeln uberpruft werden (siehe z.B. Spalte 9, Zeilen 4-9). 

3.4 Die Anordnung nach Anspruch 10 ist ebenfalls bereits aus D1 bekannt. Der 
einzige Unterschied zur Anordnung nach Anspruch 6 besteht darin, daB die 
beiden Dateien (40, 45) auf einer anderen "Unteranordnung" untergebracht sind 
als der Rest das Systems. Diese sehr allgemeine Formulierung laBt sich jedoch 
ohne weiteres auf das in D1 gezeigte System lesen (siehe z.B. Figur 5). 

3.5 Die abhangigen Anspruche 3, 9, 11, und 14 enthalten keine Merkmale, die in 
Kombination mit den Merkmalen irgendeines Anspruchs, auf den sie sich 
beziehen, die Erfordernisse des PCT in bezug auf erfinderische Tatigkeit erfullen. 
Die Grunde dafur sind die folgenden: 

3.5.1 Anspruche 3, 9 und 14: die Erweiterung des Systems aus D1 zur Beschreibung 
einer technischen Anlage ist fur den Fachmann naheliegend. 

3.5.2 Anspruch 1 1 : Auch die Kopplung verschiedener Anordnungen durch 
Kommunikationsnetze ist eine naheliegende MaRnahme. 

Zu Punkt VII 

Bestimmte Mangel der internationalen Anmeldung 

1. Die unabhangigen Anspruche sind nicht in der zweiteiligen Form nach Regel 6.3 
b) PCT abgefaBt. Im vorliegenden Fall erscheint die Zweiteilung jedoch 
zweckmaBig. Folglich hatten die in Verbindung miteinander aus dem Stand der 
Technik bekannten Merkmale (Dokument D1) in einem Oberbegriff zu- 
sammengefaBt (Regel 6.3 b) i) PCT) und die ubrigen Merkmale in einem 
kennzeichnenden Teil aufgefuhrt werden sollen(Regel 6.3 b) ii) PCT). 

2. Im Widerspruch zu den Erfordemissen der Regel 5.1 a) ii) PCT werden in der 
Beschreibung weder der in dem Dokument D1 offenbarte einschlagige Stand der 
Technik noch dieses Dokument angegeben. 
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Zu Punkt VIII 

Bestimmte Bemerkungen zur internationalen Anmeldung 

1 . Die Merkmale des Anspruchs 5 werden in der Beschreibung nicht genannt. Der 
Anspruch wird daher nicht, wie in Artikel 6 PCT vorgeschrieben, von der Be- 
schreibung gestutzt. 
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Paten tan spriiche 

1 . Verf ahren zur Bestimmung einer graphischen Struktur eines 
technischen Systems, 

a) bei dem aus einer Menge mehrerer unterschiedlicher Gra- 
phen-Struktur-Dateien eine Graphen-Struktur-Datei aus- 
gewahlt wird, wobei in einer Graphen-Struktur-Datei je- 
weils angegeben ist, welche Elemente zu deren Darstel- 
lung ausgewahlt werden konnen, um das technische System 
in seiner Struktur graphisch zu beschreiben, 

b) bei dem Elemente ausgewahlt werden der art, da£ mit den 
ausgewahlten Elementen das technische System beschrie- 
ben wird, und 

c) bei dem die Elemente von einem Editor-Programm darge- 
stellt werden, in welches die ausgewahlte Graphen- 
Struktur-Datei eingebunden worden ist, womit die gra- 
phische Struktur des technischen Systems bestimmt ist. 

2. Verf ahren nach Anspruch 1, 

bei dem das technische System eine elektronische Schaltung 
ist. 

3. Verf ahren nach Anspruch 2, 

bei dem das technische System eine technische Anlage ist. 

4. Verf ahren nach einem der Anspruche 1 bis 3, 

bei dem die Elemente Graphenelemente eines Graphen sind, die 
das technische System beschreiben. 

5. Verf ahren nach einem der Anspruche 1 bis 4, 

bei dem die bestimmte graphische Struktur des technischen 
Systems auf vorgegebene Strukturregeln hin tiberpruft wird. 

6. Anordnung zur Bestimmung einer Graphen-Struktur eines 
technischen Systems, 

a) mit einem Speicher, in dem eine Menge mehrerer unter- 



schiedlicher Graphen-Struktur-Dateien gespeichert sind, 
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wobei in eirier Graphen-Struktur-Datei jeweils angegeben 
ist, welche Elemente zu deren Darstellung ausgewahlt 
werden k5nnen, urn einen Graphen zu bilden, 

b) mit einer Auswahleinheit, mit der eine Graphen- 
Struktur-Datei aus der Menge der Graphen- St ruktur- 
Dateien ausgewahlt werden kann, 

c) mit einem Prozessor, der derart eingerichtet ist, dafi 
ein Editor-Programm ausftthrbar ist, mit welchem Editor- 
Programm unter Verwendung einer aus der Menge der Gra- 
phen-Struktur-Datei en ausgewahlten Graphen-Struktur- 
Datei ein Graph mit Elementen der ausgewahlten Graphen- 
Struktur-Datei bestimmt werden kann, womit die Graph en- 
Struktur bestimmt ist, 

d) mit einer mit dem Editor-Programm gekoppelten Darstel- 
lungskomponente, mit der die bestimmte Graphen-Struktur 
dargestellt werden kann. 

7 . Anordnung nach Anspruch 6, 

bei der mit dem Graphen eine Struktur eines technischen Sys- 
tems beschrieben wird. 

8. Anordnung nach Anspruch 7, 

bei der das technische System eine elektronische Schaltung 
ist . 

9. Anordnung nach Anspruch 7, 

bei der das technische System eine technische Anlage ist. 

10. Anordnung nach Anspruch 6, 

a) mit einer ersten Unter anordnung, die den Speicher auf- 
weist, 

b) mit einer mit der ersten Unter anordnung gekoppelten 
zweiten Unter anordnung, die folgende Komponenten auf- 
weist : 

- die Auswahleinheit, 

- das Editor-Programm, 

- die Darstellungskomponente . 
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11. Anordnung nach Anspruch 10, 

bei dem die erste Unteranordnung und die zweite Unteranord- 
nung uber ein Kommunikationsnetz miteinander gekoppelt sind. 



12. Satz von Anordnungen nach Anspruch 10 oder 11, 
bei dem mit dem Graphen eine Struktur eines technischen Sys- 
tems beschrieben wird. 

10 13. Anordnung nach Anspruch 12, 

bei dem das technische System eine elektronische Schaltung 

ist. 



5 



15 



14. Anordnung nach Anspruch 12, 

bei dem das technische System eine technische Anlage ist 
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£tf4BER DIE INTERNATIONALE ZUMl 
^PJF DEM GEBIET DES PATENT^PE 

PCT 

INTERN ATIONALER RECHERCHENBERICHT 

{Artikel 18 sowie Regeln 43 und 44 PCT) 



MEN ARBEIT 
ENS 



Aktenzeichen des Anmelders Oder Anwafts 

GR 98P2477P 


WEITERES siehe Mitteilung uber die Ubermittlung des internationalen 

Recherchenberichts (Formblatt PCT/lSA/220) sowie, soweit 
VORGEHEN zutreffend, nachstehender Punkt 5 


Internationales Aktenzeichen 

PCT/DE 99/02753 


Internationales Anmeldedatum 
(Tag/Monat/Jahr) 

01/09/1999 


(Fruhestes) Prioritatsdatum (Tag/Monat/Jahr) 

02/09/1998 


Anmelder 

SIEMENS AKTIENGESELLSCHAFT et al. 



Dieser international Recherchenbericht wurde von der Internationalen Recherchen be horde erstellt und wird dem Anmelder gemaR 
Artikel 18 ubermittelt. Eine Kopte wird dem Internationalen Biiro ubermittelt. 

Dieser internationale Recherchenbericht umfaGt insgesamt _2 Blatter. 

[X| DarCiber hinaus liegt ihm jeweils eine Kopie der in diesem Bericht genannten Unterlagen zum Stand der Technik bei. 



1. Grundlage des Berichts 

a 



Hinsichtlich der Sprache ist die internationale Recherche auf der Grundlage der internationalen Anmeldung in der Sprache 
durchgefuhrt worden, in der sie eingereicht wurde, sofern unter diesem Punkt nichts anderes angegeben ist. 



b. 



□ 
□ 
□ 
□ 



2. 
3. 



Die internationale Recherche ist auf der Grundiage einer bei der Behdrde eingereichten Obersetzung der internationalen 
Anmeldung (Regel 23.1 b)) durchgefuhrt worden. 

Hinsichtlich der in der internationalen Anmeldung often barten Nucleotid- und/oder Aminosauresequenz ist die internationale 
Recherche auf der Grundlage des Sequenzprotokolls durchgefuhrt worden, das 

| | in der internationalen Anmeldung in Schriflicher Form enthalten ist. 

zusammen mit der internationalen Anmeldung in computerlesbarer Form eingereicht worden ist. 
bei der Behdrde nachtraglich in schriftiicher Form eingereicht worden ist. 
bei der Behdrde nachtraglich in computerlesbarer Form eingereicht worden ist. 

Die Erklarung, daB das nachtraglich eingereichte schriftliche Sequenzprotokoll nicht uber den Offenbarungsgehalt der 
internationalen Anmeldung im Anmeldezeitpunkt hinausgeht, wurde vorgelegt. 

| | Die ErklSrung, daS die in computerlesbarer Form erfaBten Information en dem schriftiichen Sequenzprotokoll entsprechen, 
wurde vorgelegt. 

| | Bestimmte Anspruche haben sich als nicht recherchlerbar erwiesen (siehe Feld I). 
| | Mangelnde Einheitllchkeit der Erfindung (siehe Feld II). 



Hinsichtlich der Bezeichnung der Erfindung 

[ X ] wird der vom Anmelder eingereichte WortJaut genehmigt. 
| | wurde der Wortlaut von der Behorde wie folgt festgesetzt: 



Hinsichtlich der Zusammen fas sung 

ry~| wird der vom Anmelder eingereichte Wortlaut genehmigt. 

wurde der Wortlaut nach Regel 38.2b) in der in Feld Ml angegebenen Fassung von der Behorde festgesetzt. Der 
j j Anmelder kann der Behorde innerhalb eines Monats nach dem Datum der Absendung dieses internationalen 
Recherchenberichts eine Stellungnahme vorlegen. 

Folgende Abbildung der Zeichnungen ist mit der Zusammenfassung zu veroffentlichen: Abb. Nr. __] 



| X j wie vom Anmelder vorgeschlagen keine der Abb. 

| | weil der Anmelder selbst keine Abbildung vorgeschlagen hat. 
| | weil diese Abbildung die Erfindung besser kennzeichnet. 
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A. KLASSIFIZIERUNG DES ANMELDUNGSGEGENSTANDES 

IPK 7 G06F17/50 G06F9/44 



Nach der International en Patentklassif ikation (IPK) Oder nach der nationaten Klassifikation und derlPK 



B. RECHERCHIERTE GEBIETE 



Recherchierter Mindestprufstoff (Klassifikationssystem und Klassifikationssymbole ) 

IPK 7 G06F 



Recherchierte aber nicht zum Mindestpriifstoff gehorende Veroffentlichungen, soweit diese unter die recherchierten Gebiete (alien 



Wahrend der internationalen Recherche konsultierte elektronische Datenbank (Name der Datenbank und evtl. verwendete Suchbegriffe) 



C. ALS WESENTLICH ANGESEHENE UNTERLAGEN 



Kategorie' 



Bezeichnung der Verfiffentlichung, soweit erforderiich unter Angabe der in Betracht kommenden Teile 



Betr. Anspruch Nr. 



US 5 691 912 A (DUNCAN ROBERT G) 
25. November 1997 (1997-11-25) 
Spalte 7, Zeile 12 - Zeile 61 
Spalte 8, Zeile 30 -Spalte 9, Zeile 

Anspruche 1,2 

Abbi ldung 5 



1-14 



□ 



Weitere Veroffentlichungen sind der Fortsetzung von Feld C zu 
entnehmen 



El 



Siehe Anhang Patantfamilie 



* Besondere Kategorien von angegebenen Veroffentlichungen 

"A" Veroffentlichung, die den altgemeinen Stand der Technik definiert, 
aber nicht als besonders bedeutsam anzusehen ist 

"E" aiteres Dokument, das jedoch erst am oder nach dem internationalen 
Anmeldedatum veroffentlicht worden fst 

"L" Veroffentlichung, die geeignet ist, einen Prioritatsanspruch zwetfelhaft er- 
scheinen zu lassen, oder durch die das Veroffentlichungsdatum einer 
anderen im Recherchenbericht genannten VerSffentlichung belegt werden 
soil oder die a us einem anderen besonderen Grund angegeben ist (wie 
ausgefuhrt) 

"0° Verdffentllchung, die sich auf eine mGndliche Offenbarung, 

eine Benutzung, eine Ausstellung oder andere MaGnahmen bezieht 

"P" Veroffentlichung, die vor dem internationalen Anmeldedatum, aber nach 
dem beanspruchten Priori t at sdatum verdffentltcht worden ist 



"T" Spatere Veroffentlichung, die nach dem internationalen Anmeldedatum 
oder dem Prioritatsdatum veroffentlicht worden ist und mit der 
Anmeldung nicht kollidiert, sondern nur zum Verstandnts des der 
Erfindung zugrunde liege nden Prinzips oder der ihr zugrundeliegenden 
Theorie angegeben ist 

"X" Veroffentlichung von besonderer Bedeutung; die beanspruchte Erfindung 
kann allein auf grund dieser Veroffentlichung nicht als neu Oder auf 
erf inderischer Tatlgkeit beruhend betrachtet werden 

"Y" Veroffentlichung von besonderer Bedeutung; die beanspruchte Erfindung 
kann nicht als auf erfinderischer Tatigkett beruhend betrachtet 
werden, wenn die Veroffentlichung mit einer oder mehreren anderen 
Veroffentlichungen dieser Kategorie in Verbindung gebracnt wird und 
diese Verbindung fur einen Fachmann nahellegend ist 

"&" Verdffentltchung, die Mitglied derselben Patantfamilie ist 



Datum des Abschlusses der internationalen Recherche 



17. Februar 2000 



Absendedatum des internationalen Recherche nberichts 



24/02/2000 



Name und Post artsch rift der Internationalen Recherchenbehorde 

Europaisches Patentamt, P. B. 5818 Patentlaan 2 
NL - 2280 HV Rijswijk 
Tel. (+31-70) 340-2040, Tx. 31 651 epo nl, 
Fax: (+31-70) 340-3016 



Bevollmdchtigter Bediertsteter 



Guingale, A 
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INTERNATIONAL SEARCH REPORT 

lation on patent family members 



Patent document 
cited in search report 



Publication 
date 



ft 



:ernatlonal Application No 

T/DE 99/02753 



Patent family 
member(s) 



Publication 
date 



US 5691912 



25-11-1997 



US 5617327 A 
US 5894420 A 
WO 9415311 A 



01-04-1997 
13-04-1999 
07-07-1994 



Form PCT/ISA/210 (patent family annex) (July 1992) 



PCT 




VELTORGANISATION FOR GEISTIGES EIGEr 
Internationales Biiro 

INTERNATIONALE ANMELDUNG VER6FFENTLICHT NACH DEM VERTRAG UBER DIE 
INTERNATIONALE ZUSAMMEN ARBEIT AUF DEM GEBIET DES PATENTWESENS (PCT) 



(51) Internationale Patentklassifikation 7 
G06F 17/50, 9/44 



Al 



(11) Internationale Veroffentlichungsnummer: WO 00/14661 

16. Marz 2000 (16.03.00) 



(43) Internationales 

Veroffentlichungsdatum: 



(21) Internationales Aktenzeichen: PCT/DE99/02753 

(22) Internationales Anmcldedatum:!. September 1999 (01.09.99) 



(30) Prioritatsdaten: 

198 39 972.3 



2. September 1998 (02.09.98) DE 
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(57) Abstract 
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(57) Zusammenfassung 



Aus einer Menge mehrercr unterschiedlichcr Graphen-Struktur-Dateien wind eine Graphen-Struktur-Datei ausgewahlt. In einer 
Graphen-Struktur-Datei ist jeweils angegeben, welche Elemente zu deren Darstellung ausgewahlt wenlen konnen, urn das technische 
System in seiner Struktur graphisch zu beschreiben. Es werden Elemente derart ausgewahlt, daB mit den ausgewahlten Elementen das 
technische System beschrieben wird, und die Elemente werden von einem Editor-Programm dargestellt, in welches die ausgewahlte 
Graphen-Struktur-Datei eingebunden worden ist. 
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Beschreibung 

Verfahren zur Bestimmung einer graphischen Struktur eines 
technischen Systems und Anordnung sowie Satz von Anordnungen 
5 zur Bestimmung einer Graphen-Struktur 

Es ist bekannt, verschiedene technische Systeme mittels einer 
graphischen Struktur zu beschreiben. 

10 Aus [1] ist fur ein solches technisches System, einer elek- 
tronischen Schaltung, bekannt, die elektrische Schaltung in 
Form einer graphischen Struktur mit Elementen, die eine elek- 
tronische Schaltung beschreiben, zu bestimmen. 

15 Elemente einer Graphen-Struktur im Rahmen einer Schaltungssi- 
mulation sind Symbole, die elektronische Bauelemente symboli- 
sieren, beispielsweise einen Widerstand, einen Kondensator, 
eine Induktivitat , einen Transistor, einen Operationsvers tar- 
ker oder andere, aus diesen Elementen zusammengesetzte elek- 

20 tronische Bauelemente. 

Bei dem aus [1] bekannten Verfahren und der aus [1] bekannten 
Anordnung werden von einem Edi tor-Programm einem Benutzer zur 
Verfiigung gestellte Elemente zur graphischen Beschreibung ei- 
25 ner elektronischen Schaltung ausgewahlt derart, daft mit den 
ausgewahlten Elementen das technische System "elektronische 
Schaltung" beschrieben wird. Die Elemente werden von dem Edi- 
tor-Programm dargestellt. 

30 Eine Graphen-Struktur beschreibt einen Graph G (= V, E, *F) , 
der eine endliche, nicht leere Menge V (v e V bezeichnen 
Knoten des Graphen G) aufweist sowie eine endliche Menge E (e 
e E bezeichnen Kanten des Graphen G) . Die Knoten und Kanten 
des Graphen werden verknupft durch eine Inzidenzf unktion 

35 die gemafl folgender Vorschrift gebildet wird: 




(1) 
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Jeder Kante e der Menge E von Kanten werden durch die Inzi- 
denzf unktion ^(e) ihre beiden Endpunkte zugeordnet. 

5 Je nach Anwendungsgebiet konnen in einem Editor-Programm zur 
Beschreibung eines technischen Systems unterschiedliche Arten 
von Knoten und Kanten vorgesehen sein. Allgemein werden Kno- 
ten und Kanten in einem Editor-Programm, denen eine anwen- 
dungsabhangige Semantik zugeordnet ist, als Elemente des Gra- 
10 phen bezeichnet. 

Ein Knotenelement eines Graphen ist beispielsweise bei dem 
Editor-Programm aus [1] ein Symbol, welches ein elektroni- 
sches Bauelement der elektronischen Schaltung symbolisiert . 
15 Mit den Kanten konnen gewichtete Verbindungen zwischen den 
einzelnen Elementen beschrieben werden. 

Allgemein kann den jeweiligen Knoten und Kanten ein Gewicht, 
eine Wertangabe oder auch ein beliebiger Text fur Information 
20 (textuelle Information) zugeordnet sein. 

Aus [2] ist ein Editor-Programm zur Bestimmung eines Petri- 
Netzes bekannt. Ein Petri-Netz wird vorzugsweise eingesetzt 
zur Analyse und zum Entwurf einer Regelungen oder einer 

25 Steuerung eines technischen Systems, allgemein zur Beschrei- 
bung eines Systemverhaltens eines technischen Systems. Ein 
Graph, der in Form eines Petri-Netzes dargestellt ist, weist 
als Elemente eine Stelle S oder auch eine Transition T auf. 
Eine allgemeine Obersicht uber ein Petri-Netz sowie dessen 

30 Grundel entente ist in [3] zu finden. 

Ein Petri-Netz ist allgemein ein Tripel 
N : = < S, T, F > 

mit 
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(i) 



S = { si 



s2 



sn } 
tm } 



Menge von Stellen 
Menge von Transitionen 
S und T disjunkt {die 
Knotenmenge besteht 
aus S und T) 
Fluftrelation 



(ii) 
(iii) 



T = { tl , 
S r> T = 0 



t2 



(iv) 



F c (SxT) (TxS) 



Nachteilig an den bekannten Verfahren und Anordnungen ist 
insbesondere, da£ jeweils anwendungsabhangig nur fur eine 
spezielle Anwendung vorgesehene Elemente eines Graphen zur 
Bestimmung der graphischen Struktur eines technischen Systems 
zur Verfugung gestellt werden. So kann mit dem Editor- 
Programm aus [1] lediglich eine Auswahl unter Elementen zur 
Beschreibung einer elektronischen Schaltung und bei dem Edi- 
tor-Programm aus [2] lediglich eine Auswahl aus Elementen zur 
Beschreibung eines Petri-Netzes erfolgen. 

Ein solches bekanntes Editor-Programm ist somit aufierst un- 
flexibel fur den Fall, daii ein Anwender unterschiedliche Ar- 
ten einer graphischen Struktur zur Beschreibung eines techni- 
schen Systems einsetzen mochte. Fur jede spezielle Anwendung 
mufi dann ein eigenes, fur die Anwendung angepaiites Editor- 
Programm entwickelt werden, was zu erheblichen Entwicklungs- 
kosten fiihrt. 

Somit liegt der Erfindung das Problem zugrunde, ein Verfahren 
zur Bestimmung einer graphischen Struktur eines technischen 
Systems sowie eine Anordnung und einen Satz mehrerer Anord- 
nungen zur Bestimmung einer Graphen-Struktur anzugeben, wel- 
che gegeniiber den bekannten Verfahren und Anordnungen eine 
verbesserte Flexibilitat aufweist. 



Das Problem wird durch das Verfahren, die Anordnung sowie den 
Satz von Anordnungen gemaft den Merkmalen der unabhangigen Pa- 
tentanspriiche gelost. 
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Ein Verfahren zur Bestimmung einer graphischen Struktur eines 
technischen Systems weist folgende Schritte auf : 

a) aus einer Menge mehrerer unterschiedlicher Graphen- 
Struktur-Dateien wird eine Graphen-Struktur-Datei ausge- 
wahlt, wobei in einer Graphen-Struktur-Datei jeweils ange- 
geben ist, welche Elemente zu deren Darstellung ausgewahlt 
werden konnen, um das technische System in seiner Struktur 
graphisch zu beschreiben, 

b) Elemente werden derart ausgewahlt, dafi mit den ausgewahl- 
ten Elementen ein technisches System beschrieben wird, und 

c) die Elemente werden von einem Editor-Programm dargestellt, 
in welches die ausgewahlte Graphen-Struktur-Datei einge- 
bunden worden ist, womit die graphische Struktur des tech- 
nischen Systems bestimmt ist. 

Eine Anordnung zur Bestimmung einer Graphen-Struktur weist 
folgende Merkmale auf : 

a) einen Speicher, in dem eine Menge mehrerer unterschiedli- 
cher Graphen-Struktur-Dateien gespeichert sind, wobei in 
einer Graphen-Struktur-Datei jeweils angegeben ist, welche 
Elemente zu deren Darstellung ausgewahlt werden konnen, um 
einen Graphen zu bilden, 

b) eine Auswahleinheit , mit der eine Graphen-Struktur-Datei 
aus der Menge der Graphen-Struktur-Dateien ausgewahlt wer- 
den kann, 

c) einen Prozessor, der derart eingerichtet ist, daft ein Edi- 
tor-Programm ausfuhrbar ist, mit welchem Editor-Programm 
unter Verwendung einer aus der Menge der Graphen-Struktur- 
Dateien ausgewahlten Graphen-Struktur-Datei ein Graph mit 
Elementen der ausgewahlten Graphen-Struktur-Datei bestimmt 
werden kann, womit die Graphen-Struktur bestimmt ist, und 

d) eine mit dem Editor-Programm gekoppelte Darstellungskompo- 
nente, mit der die bestimmte Graphen-Struktur dargestellt 
werden kann. 

Ein Satz mehrerer Anordnungen zur Bestimmung einer Graphen- 
Struktur weist auf: 
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5 

a) eine erste Anordnung, die einen Speicher aufweist, in dem 
eine Menge mehrerer unterschiedlicher Graphen-Struktur- 
Dateien gespeichert sind, wobei in einer Graphen-Struktur- 
Datei jeweils angegeben ist, welche Elemente zu deren Dar- 
stellung ausgewahlt werden konnen, um einen Graphen zu 
bilden, und 

b) eine mit der ersten Anordnung gekoppelte zweite Anordnung, 
die folgende Komponenten aufweist: 

- eine Auswahleinheit, mit der eine Graphen-Struktur-Datei 
aus der Menge der Graphen-Struktur-Dateien ausgewahlt 
werden kann, 

- ein Editor-Programm, mit dem unter Verwendung aus der 

Menge der Graphen-Struktur-Dateien ausgewahlten Gra- 
phen-Struktur-Datei ein Graph mit Elemenenten der aus- 
15 gewahlten Graphen-Struktur-Datei bestimmt werden kann, 

womit die Graphen-Struktur bestimmt ist, 

- eine mit dem Editor-Programm gekoppelte Darstellungskom- 

ponente, mit der die bestimmte Graphen-Struktur darge- 
stellt werden kann. 

20 

Durch die Erfindung wird ein gegeniiber den bekannten Verfah- 
ren und Anordnungen sehr flexibles Verfahren und eine sehr 
flexible Anordnung zur Bestimmung einer graphischen Struktur 
angegeben, welche schnell und unkompliziert an neue Anwen- 
25 dungsszenarien bzw. an bestehende Anwendungsszenarien besser 
angepafit werden kann. 



Auf diese Weise werden verschie 
als Graph darstellbar sind, mit 
30 ner Anordnung auf flexible, kos 
bearbeitbar . 



dene Arten von Strukturen, die 

einem Verfahren bzw. mit ei- 
tengunstige und einfache Weise 



Bevorzugte Weiterbildungen der Erfindung ergeben sich aus den 
abhangigen Ansprilchen. 

35 

Das technische System ist vorzugsweise eine elektronische 
Schaltung oder eine technische Anlage. 
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Die Elemente sind vorzugsweise Graphen-Elemente eines Gra- 
phen, die das technische System beschreiben. 

In einer weiteren Ausgestaltung ist es vorgesehen, daft die 
bestimmte graphische Struktur des technischen Systems auf 
vorgegebene S trukturregeln hin uberpriift wird. Auf diese Wei- 
se ist es mdglich, eine von einem Benutzer bestimmte Struktur 
des technischen Systems auf vorgegebene Strukturregeln hin zu 
uberpriifen, wodurch die Einhaltung der Strukturregeln fur das 
jeweilige technische System in seiner graphischen Struktur 
gewahrleistet ist. 

Eine solche Strukturregel ist bei einem Petri-Netz beispiels- 
weise darin zu sehen, daft immer auf eine Transition eine 
Stelle folgen muft und umgekehrt. Ist dies nicht der Fall, so 
wird im Rahmen dieser Weiterbildung bei der Oberprufung der 
graphischen Struktur eines Petri-Netzes gemeldet, daft die 
entsprechende Strukturregel verletzt ist. 

Ein Ausfuhrungsbeispiel der Erfindung ist in den Figuren dar- 
gestellt una wird im weiteren naher erlautert. 

Es zeigen 

Figur 1 eine Skizze einer Anordnung gemaft einem ersten Aus- 
fuhrungsbeispiel ; 

Figur 2 eine Skizze einer Darstellungskomponente mit einer 
graphischen Struktur mit Elementen eines Petri- 
Netzes ; 



Figur 



3 



eine Skizze einer Darstellungskomponente mit einer 
graphischen Struktur mit Elementen, die eine elektro- 
nische Schaltung beschreiben; 
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Figur 4 ein Ablauf diagramm, in dem die Ver f ahrensschritte des 
Verfahrens gemaft einem Ausfuhrungsbeispiel darge- 
stellt sind; 

Figur 5 ein Satz mehrerer Anordnungen, die gemaB einem zwei- 
ten Ausfuhrungsbeispiel uber ein Kommunikationsnetz 
miteinander gekoppelt sind. 

Fig. 1 zeigt eine Anordnung 100 mit einer Menge 101 mehrerer 
unterschiedlicher Graphik-Struktur-Dateien 102, 103, 104, 
105. Jede Graphik-Struktur-Datei 102, 103, 104, 105 ist als 
dynamisch bindbare Datei (dynamic link library) ausgestaltet . 

Von einem Benutzer 106 wird uber eine mit einem Editor- 
Programm 107 verbundenen Auswahlkomponente 108 {Tastatur 
und/oder Computermaus ) eine Graphik-Struktur-Datei 102, 103, 
104, 105 ausgewahlt. 

Die ausgewahlte Graphik-Struktur-Datei, in diesem Ausfuh- 
rungsbeispiel eine erste Graphik-Struktur-Datei 103, wird dy- 
namisch in das Editor-Programm 107 eingebunden. 

Nach Einbindung in das Editor-Programm 107 ist uber eine mit 
dem Editor-Programm 107 verbundene Darstellungskomponente 109 
dem Benutzer 106 auf einem Bildschirm 110 eine Menge 111 von 
auswahlbaren Elementen 112, 113, 114, die in der ersten Gra- 
phik-Struktur-Datei 103 angegeben sind, als auswahlbare Ele- 
mente zur Bestimmung eines weiteren beschriebenen Graphen 
dargestellt. Ferner sind in diesem Ausfuhrungsbeispiel gemafl 
der ersten Graphik-Struktur-Datei 103 ein erstes Uberpru- 
fungsprogramm 115 sowie ein zweites Oberpruf ungsprogramm 116 
in dem Editor-Programm 107 eingebunden und werden dem Benut- 
zer 106 zur Auswahl zur Verfiigung gestellt. 

Jede Graphik-Struktur-Datei 102, 103, 104, 105 weist jeweils 
eine Menge auswahlbarer Elemente fur die jeweilige Art von 
Graphen auf, wobei jeweils eine Graphik-Struktur-Datei vorge- 
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sehen ist fur eine Art eines Graphen. Ferner kann jede Gra- 
phik-Struktur-Datei 102, 103, 104, 105 jeweils ein spezielles 
Oberprtif ungsprogramm enthalten, welches mit der jeweiligen 
Graphik-Struktur-Datei 102, 103, 104, 105 eingebunden wird. 

5 

Nach Einbindung der ersten Graphik-Struktur-Datei 103 werden 
von dem Benutzer 106 Elemente des Graphen ausgewahlt und mit- 
einander verbunden, so daii ein Graph bestimmt wird, der in 
Form einer vorgegebenen Zwischensprache 117 in einem Speicher 
10 118 gespeichert ist. 

Symbolisch ist in Fig. 1 ferner dargestellt, daft von dem Be- 
nutzer 106 zu der durch die erste Graphikdatei 103 vorgegebe- 
nen Art eines Graphen mehrere Strukturen 119, 120, 121, 122, 
15 123 zur Beschreibung unterschiedlicher Graphen gespeichert 
sind. 

Die erste Graphik-Struktur-Datei 103 stellt Elemente zur Ver- 
fugung, die einen Graphen in Form eines Petri-Netzes 201 er- 
20 moglicht (vergleiche Fig . 2 ) . 

Fig. 2 zeigt die Darstellungskomponente 200, die in Form einer 
Bildschirmoberf lache dem Benutzer 106 dargestellt wird. 

25 Die Bildschirmoberf lache 200 weist eine Menuleiste 202 mit 
unterschiedlichen auswahlbaren Optionen („File", „Edit xx , 
„Object", „View v \ „Tools", „Settings", „Help") auf . 

Ober eine Sof ort-Zugrif f sleiste 203 werden dem Benutzer uber 
30 einzelne auswahlbare Elemente Menupunkte durch einmaliges, 
direktes Auswahlen eines Elementes zur Verfugung gestellt. 

Ferner ist eine Bearbeitungsleiste 204 dargestellt mit aus- 
wahlbaren Optionen zur Bestimmung des Graphen. So ist bei der 
35 ersten Graphik-Struktur-Datei 103 ein erstes Auswahlelement 

205 vorgesehen, mit dem eine Auswahl und eine Bearbeitung von 
auf dem Bildschirm dargestellten Objekten moglich ist. 
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Ober eine Menge 206 weiterer, im weiteren naher erlauterter 
Auswahlelemente ist die Auswahl unci Bearbeitung spezifischer 
Elemente fur ein Petri-Netz 201 dem Benutzer 106 zur Verfii- 
5 gung gestellt. 

Ein zweites Auswahl element 207 ist beschrieben durch ein lee- 
res Rechteck und symbolisiert eine zeitbehaf tete Transititon. 

10 Ein drittes Auswahl element 208 symbolisiert eine zeitlose 

Transition, die als ausgewahlte Transisitions-Elemente 220, 
221 und 222 in dem Petri-Netz 201 dargestellt sind. 

Ein viertes Auswahlelement 209 symbolisiert eine Kante, die 
15 in diesem Aus f uhrungsbeispiel eine gerichtete Kante ist. 

Ein fiinftes Auswahlelement 210 symbolisiert eine gemaft der 
Strukturregeln eines Petri-Netzes 201 bezeichnete verbotene 
Kante . 

20 

Ein sechstes Auswahlelement 211 symbolisiert eine Stelle, wo- 
bei jeweils ein Stellen-Element 223, 224, 225, 226 in dem 
Petri-Netz 201 dargestellt sind. Die Stellen-Elemente 223, 
224, 225 und 226 sind mit den Transition-Elementen 220, 221, 
25 222 iiber Kanten 227, 228, 229, 230, 231 und 232 verbunden. 

Ein siebtes Auswahlelement 212 symbolisiert die Moglichkeit, 
eine Kombination mehrerer Elemente des Petri-Netzes zu einem 
Gesamtelement zusammenzuf assen . 

30 

Ein achtes Auswahlelement 213 symbolisiert einen Eingang des 
Petri-Netzes 201 und ein neuntes Auswahlelement 214 symboli- 
siert einen Ausgang eines Petri-Netzes 201. 

35 Den Kanten sowie den einzelnen Knoten, das heifit den Elemen- 
ten des Petri-Netzes 201 sind textuelle Inf ormationen 251, 
252, 253, 254, 255, 256, 257, 258, 259, 260 und 261 zugeord- 
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net. Auf diese Weise ist es moglich, den einzelnen Elementen 
eine zusatzliche textuelle Beschreibung zuzuordnen. 

Ist eine zweite Graphik-Struktur-Datei 104 in das Editor- 
5 Programro 107 eingebunden, wobei die zweite Graphik-Struktur- 
Datei 104 Elemente einer elektronischen Schaltung und somit 
einen Graphen einer elektronischen Schaltung zur Verfugung 
stellt, so ergibt sich eine in Fig. 3 dargestellte Bild- 
schirmoberf lache mit einer fur die Schaltungssimulat ion ein- 
10 gerichtete Menge von Auswahlelementen . 



15 



Fur die gleichen Elemente der Bildschirmoberf lache, wie sie 
in Fj -g- 2 dargestellt sind, werden in Fig. 3 die gleichen Be- 
zugszeichen verwendet . 



Eine Menge 301 von Auswahlelementen, die spezifisch sind zur 
Beschreibung eines Graphen einer elektronischen Schaltung, 
enthalten 

• ein zehntes Auswahlelement 302, welches einen elektroni- 
20 schen Widerstand symbolisiert, 

• ein elftes Auswahlelement 303, welches einen elektronischen 
Kondensator symbolisiert, 

• ein zwolftes Auswahlelement 304, welches eine Induktivitat 
symbolisiert, 

25 • ein dreizehntes Auswahlelement 305, symbolisierend einen 
Transistor, 

• ein vierzehntes Auswahlelement 306, symbolisierend einen 
Operationsverstarker, 

• ein funfzehntes Auswahlelement 307, symbolisierend eine un- 
30 gerichtete Kante, und 

• ein sechzehntes Auswahlelement 308, symbolisierend eine 
Stromquelle . 

Eine elektronische Schaltung 110 wird durch den Benutzer 106 
35 bestimmt und weist in diesem Ausf uhrungsbeispiel eine Strom- 
quelle 311, elektronische Widerstande 312, 313, elektronische 
Kapazitaten 314 und 315 sbwie einen Operationsverstarker 316 



WO 00/14661 



PCT/DE99/02753 



11 

auf, die jeweils iiber Kanten 317 miteinander verbunden sind. 
Ferner ist ein Masseanschluft 318 in Fig. 3 dargestellt. Den 
einzelnen Schaltungselementen ist textuelle Information 319, 
320, 321, 322, 323, 324, 325, 326 zugeordnet zur naheren Er- 
5 lauterung der elektronischen Schaltung 310. 

Fig. 4 zeigt zur Verdeutlichung des Verfahrens das Verfahren 
in seinen Ver f ahrensschri tten . 

10 In einem ersten Schritt (Schritt 401) wird eine Graphik- 
Struktur-Datei 102, 103, 104, 105 aus einer Menge 101 von 
Graphik-Struktur-Dateien 102, 103, 104, 105 ausgewahlt. 

In einem zweiten Schritt {Schritt 402) erfolgt eine Auswahl 
15 von Elementen, die gemaft der Graphik-Struktur-Datei 102, 103, 
104, 105, die in dem Schritt zuvor (Schritt 401) ausgewahlt 
wurde, zur Verfugung stehen. 

Die ausgewahlten Elemente werden von dem Editor-Programm 107 
20 in einem weiteren Schritt (Schritt 403) dargestellt. 

Fig. 5 zeigt einen ersten Rechner 500 mit einem Speicher 502 
und einem Prozessor 503, die jeweils iiber einen Bus 504 mit- 
einander und mit einer Eingangs-/Ausgangsschnittstelle 501 
25 verbunden sind. 

Uber die Eingangs-/Ausgangsschnittstelle 501 ist der erste 
Rechner 500 mit einem Bildschirm 505, einer Tastatur 506 so- 
wie einer Computermaus 507 verbunden. 

30 

Ferner ist der erste Rechner 500 iiber ein Kommunikationsnetz 
560, in dem Ausf uhrungsbeispiel ein ISDN-Netz (Integrated 
Services Digital Network) mit weiteren Rechnern 510, 520, 
530, 540 und 550 verbunden. 

35 

In dem ersten Rechner 500 ist die Menge 101 der Graphik- 
Struktur-Dateien 102, 103,' 104, 105 gespeichert. 
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Die weiteren Rechner 510, 520, 530, 540 und 550 weisen j e- 
weils ebenfalls einen Prozessor 513, 523, 533, 543 und 553 
sowie jeweils einen Speicher 512, 522, 532, 542 und 552 auf. 
5 Jeweils der Prozessor 513, 523, 533, 543 und 553 und der 

Speicher 512, 522, 532, 542 und 552 sind liber jeweils einen 
Bus 514, 524, 534, 544 und 554 uber eine Eingangs- 
/Ausgangsschnittstelle 511, 521, 531, 541 und 551 mit dem 
Kommunikationsnetz 560 verbunden. Ferner sind die weiteren 
10 Rechner 510, 520, 530, 540 und 550 jeweils mit einem Bild- 
schirm 515, 525, 535, 545 und 555 sowie einer Tastatur 516, 
526, 536, 546 und 556 sowie einer Computermaus 517, 527, 537, 
547 und 557 verbunden. 

15 In jedem Rechner 500, 510, 520, 530, 540 und 550 ist ein Edi- 
tor-Programm 508, 518, 528, 538, 548, 558 gespeichert. Von 
einem Benutzer eines weiteren Rechners 510, 520, 530, 540 und 
550 wird eine Graphik-Struktur-Datei 102, 103, 104, 105 aus- 
gewahlt und bei dem ersten Rechner 500 angefordert mit einer 

20 Anforderungsnachricht 570. Der erste Rechner 500 sendet die 
ausgewahlte Graphik-Struktur-Datei 102, 103, 104, 105 in ei- 
ner Antwortnachricht 580 an den die Graphik-Struktur-Datei 
102, 103, 104, 105 anfordernden weiteren Rechner 510, 520, 
530, 540 und 550. 

25 

Damit hat der anfordernde weitere Rechner 510, 520, 530, 540 
und 550 die angeforderte Graphik-Struktur-Datei 102, 103, 
104, 105 erhalten und bindet diese in sein Editor-Programm 
518, 528, 538, 548, 558 ein, wie im ersten Ausf uhrungsbei- 
30 spiel beschrieben. 

Im weiteren werden einige Alternativen zu den oben beschrie- 
benen AusfUhrungsbeispielen dargestellt: 



35 



Die Art der Elemente, die von einer Graphik-Struktur-Datei 
zur Verfugung gestellt werden, ist allgemein beliebig und le- 
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diglich von der jeweiligen Art des zu bestimmenden Graphen 
abhangig . 

Das technische System kann beispielsweise auch eine techni- 
5 sche Anlage sein, die durch den Graphen in ihrem Verhalten 
oder in ihrer Struktur beschreibbar ist. 

Das Editor-Programm sowie der mit dem Editor-Programm darge- 
stellte Graph kann im Rahmen einer Simulation des technischen 
10 Systems eingesetzt werden. 
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In diesem Dokument sind folgende Verof f entlichungen zitiert: 

[1] Verof fentlichung im Internet erhaltlich am 2. September 
1998 unter der Adresse: 

http: //www. redac. co.uk/prod_info/brochures/14a .html 

[2] G. Chiola, G. Franceschinis, R. Gaeta and M. Ribaudo, 

GreatSPN 1.7: Graphical Editor and Analyzer for Timed and 
Stochastic Petri Nets, Performance Evaluation, special 
issue on Perfomance Modelling Tools, 24 (1&2), 
S. 47 - 68, November 1995 

[3] G. Schmidt, Grundlagen der Regelungstechnik : Analyse und 

Entwurf linearer und einfacher nichtlinearer Regelungen 

sowie diskreter Steuerungen, zweite Auflage, Springer- 

Verlag, ISBN 3-54 0-17112-6, Berlin, S. 320 - 328, 1991 
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Im weiteren ist eine Realisierung des oben beschriebenen Aus- 
f uhrungsbeispiels angegeben, geschrieben in der Programmier- 
sprache C, wobei die Realisierung in drei Dateien aufgeglie- 
dert ist: 



1. Initialisierungs-Datei : 



package interfaces; 

import j ava . io . * ; 
import java.util.*; 
import java.awt. *; 

import etc . * ; 
import elements . * ; 
import mmi . * ; 
import tools.*; 

public class Initialisierung { 

GraphEditor editor ; 

// Der hat die Tokens aus der 
Datei 

StreamTokenizer token; 

// Hier kommen alle erlaubten 
Knoten und Kanten aus der 

/ / . lgc Datei rein . 

// Die Eintrage werden mit den 
Namen der Objekte referenziert 

Hashtable gob j ekte ; 

// Die aktuelle .lgc Datei 

//String configFile; 

// steht jetzt bei den Einstel- 

lungen 
/ + * 

* Hier stehen alle Attribute 
drin . 

*/ 

Hashtable attributNamen; 

* hier kommen die Eintrage fiir 
das Menue Tools 

* hinein. 
*/ 

Hashtable tools; 

public Initialisie- 
rung {GraphEditor editor) ( 

this. editor — editor; 

gob j ekte = new Hashtable () ; 

attributNamen = new Has- 
htable ( ) ; 

tools = new Hashtable { ) ; 

} 



/ 



** 



* Diese Methode wurde die er- 
ste Initialisierungsdatei 



* einlesen fiir die Einstellu- 
60 gen der Farben, Schriften. . . 

* Aber ich darf leider nicht. 
*/ 

/* 

public void readFirst ( String 
65 name) { 

String configFile = new 
String (name) ; 
int c; 

//Properties properties = new 

7 0 Properties () ; 

//properties = Sy- 
stem. getProperties { ) ; 

//filename = new String (".." 
+ proper- 

75 ties . get Property ( "file . separator" 
) + configfile) ; 
try { 

File file = new 
File (configFile) ; 
80 //FilelnputStream in - new 

FilelnputStream ( f ile) ; 

FileReader in = new File- 
Reader ( f ile ) ; 

token = new StreamTokeni- 

8 5 zer ( in ) ; 

//Einstellen der Optionen 
fur token 
to- 

90 ken. eollsSignif icant (true) 
token . quoteChar ( 1 " ' ) 
// token. quoteChar ( ' \ ' ' ) ; 
//token . quoteChar ('{'); 
token. quoteChar ('}'); 

95 

/ /Oberlese { und , und ; 
to- 
ken. whitespaceChars ( ' {','{') ; 
to- 

100 ken. whit espaceChars ( ' , 1 , ' , * ) ; 
to- 
ken . whitespaceChars ( 1 ; 1 , ' ; 1 ) ; 



105 boolean fertig = false; 

while {! fertig) { 
switch 
(c=token . nextToken ( ) ) { 
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zer.TT EOF: 



zer.TT WORD: 



case StreamTokeni- 

fertig= true; 
break; 
case StreamTokeni- 

if 



(token, sval . equals ("DATAPATH") ) ( 

c=token . nextToken ( ) ; 

if ( c == 1 " ' ) ( 

Sy- 
stem . out . println ( "DATAPATH " + 
token . sval ) ; 



} 



break ; 



} 

if 



(token. sval. equals ( "DATAFILTER" ) ) 
< 

c=token . nextToken ( ) ; 

if ( C == * " ' ) { 
Sy- 
stem, out .println ( "DATAFILTER " + 
token . sval J ; 

i 

break; 

} 

if 

(token. sval. equals ( "FILELIST" ) ) { 

while (c ! = » } • ) 

{ 

c=token . nextToken ( ) ; 

if (c == 

. « , } { 

edi- 
tor . getMenueleiste ( ) . addFileToMen 
u (token . sval ) ; 

J 

) 

break ; 

} 

if 

(token. sval. equals ("COLORS") ) { 

while (c != ' } ' ) 

t 

c=token. nextToken ( ) ; 

if (c — Stre- 
amTokenizer . TT_W0RD) { 

String aus- 

wahl = token . sval ; 

c=token . nextToken ( ) ; 

//System, out . print ( "Wertl " + to- 
ken . nval ) ; 

int r = 

(int) token. nval; 



c=token . nextToken ( ) ; 



65 //System. out . print ( "Wert2 " + to- 
ken . nval ) ; 

int g = 

(int ) token . nval ; 

7 0 c=token. nextToken () ; 

//System. out. println ("Wert3 " + 
token . nval ) ; 

int b = 

7 5 (int ) token . nval ; 

//System. out . flush ( ) ; 

ueberge- 

be ( auswahl , r, g, b) ; 
80 ) 

) 

break ; 

} 

if 

8 5 (token. sval. equals ("FONTS") ) { 

while (c != * } ' ) 

{ 

c=token . nextToken ( ) ; 
90 if (c -= Stre- 

amTokenizer .TT_W0RD) { 

String aus- 
wahl = token . sval ; 

95 //System, out. print ( "FONT " + to- 
ken . sval ) ; 



c=token . nextToken ( ) ; 
100 name — token . sval; 



String font- 



/ /System, out .print ( " NAME " + to- 
ken . sval ) ; 



105 c=token . nextToken () ; 



= token. sval; 



String style 



//System, out. print (" STYLE " + 
110 token. sval); 

c=token . nextToken ( ) ; 

int size 

= (int) token. nval; 
115 ueberge- 

be ( auswahl , fontname, style, size ) ; 

//System, out .println ( " SIZE " + 
token . nval ) ; 
120 ) 

) 

break; 
} 
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if 

(token. sval .equals ("SHORTCUTS") ) 



{ 

5 { 



while (c != * } ' ) 



c=token . nextToken ( ) ; 

if (c == * ) 

{ 

10 String 
mpunkt = token. sval; 



15 



//System. out . print ( "MENUPUNKT " + 
token . sval ) ; 



c=token . nextToken ( ) ; 



= token. sval; 



String iconl 



2 0 //System. out .print ( "ICON1 " + to- 
ken . sval ) ; 



c=token . nextToken ( ) ; 
25 = token. sval; 



String icon2 



//System. out -println ( "ICON2 " + 
token. sval ) ; 

edi- 

30 tor . getShortcutleiste ( ) . addShortB 
utton ( ) ; 



J 



} 



35 



break; 



} 

if 



< token . sval . equals ( "ACCELERATOR" ) 

) { 

while <c != ' } * ) 



40 { 



17 
65 



70 



75 



80 



85 



90 



95 



100 



c=token . nextToken ( ) ; 

if ( C == • " ' ) { 105 
String la- 

4 5 bel = token, sval; 

/ / System, out . print ( "MENUPUNKT " + 
token. sval); 110 

5 0 c=token . nextToken ( ) ; 

if (c == 
StreamTokenizer ,TT_WORD) { 

char cut - 115 

token . sval . charAt ( 0) ; 

55 

//System. out. println (" TASTEN " + 
cut) ; 

edi- 120 
tor . getMenueleiste ( ) . addShortcutT 
60 oVector (label, cut) ; 



} 



} 

break; 

) 

if 

(token. sval. equals ( "WINDOWSIZE" ) ) 
{ 



c=token . nextToken ( ) ; 

int x 

= ( int ) token . nval ; 

c=token . nextToken ( ) ; 

c=token. nextToken ( ) ; 

int y 

— (int ) token . nval ; 

//size.setSize (x, y) ; 

break; 

> 

if 

(token . sval . equals ( "WINDOWPOSITIO 
N" ) } { 

c=token. nextToken ( ) ; 

int x 
= ( int ) token . nval ; 

c=token . nextToken ( ) ; 

c=token . nextToken ( ) ; 

int y 

- (int ) token. nval ; 

//location . setSize (x, y) ; 

break; 



} 



if 



(token . sval . equals ( "AUTHOR" ) ) { 

c=token . nextToken ( ) ; 

if ( C == * "' ) { 
Sy- 
stem, out .println ( "AUTHOR " + to- 
ken . sval ) ; 

) 

break; 

} 

if 

(token. sval. equals ("TOOLS" ) ) { 

while (c != ' } ' ) 

{ 

c=token . nextToken ( ) ; 

if ( C == 1 " 1 ) 

[ 

String pfad 
-new String ( token . sval ) ; 

/ / System. out . println ( "TOOL " + 
token . sval ) ; 



} 
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10 



15 



20 



c=token . nextToken ( ) ; 

String fi- 

leName =new String ( token . sval ) ; 

// System. out . println ( "TOOL " + 
token - sval ) ; 

c=token . nextToken ( ) ; 

String text 
=new String (token . sval ) ; 

//System. out . println ( "TOOL " + 
token . sval ) ; 

edi- 
tor . getMenueleiste ( ) . addToolToVec 
tor (pfad, fileName, text) ; 

) 

} 

break ; 
} else 
break; 



default 



25 



} 



in . close ( ) ; 

System. out . flush ( ) ; 
30 System. out .println { "EINLESEN 

DER DAT EI " +configFile + " 
FERTIG! ") ; 

} catch 

35 (FileNotFoundException e) { 

System. err . println ( con- 
figFile + " is not found"); 

) catch (IOException e) { 
e . printStackTrace { ) ; 

40 } 

} //read first 
*/ 



45 



/ 



* Diese Methode liest eine 
Toolbar ein. 

* Sie benotigt den Pfad zur 
Datei und den Dateinamen. 

50 */ 

public void readSecond ( String 
lgcPath, String datei) { 

String configFile = new 
String (lgcPath + datei); 
55 int c; 

try { 

File file = new 
File (configFile) ; 

FileReader in = new File- 
60 Reader (file) ; 

token = new StreamTokeni- 
zer (in) ; 



//Einstellen der Optionen 
65 fur token 

to- 
ken . eolls Significant (false ) ; 

token. quoteChar ('"*); 

//token . quoteChar ( * \ 1 ' ) ; 
70 //token . quoteChar ( M M ; 

token . quoteChar (MM; 

//Uberlese { und , und ; 
to- 

75 ken . whitespaceChars (MM MM; 

to- 
ken . whitespaceChars ( M M M M ; 

to- 
ken . whitespaceChars ( M* M MM; 

80 



boolean fertig = false; 
while (! fertig) { 
85 switch 

( c=token . nextToken ( ) ) ( 

case StreamTokeni- 

zer . TT_EOF: 

fertig= true; 
90 break; 

case StreamTokeni- 

zer . TT_WORD: 

if 

( token . sval . equals ( "TOOLBAR" ) ) { 
95 sy- 
stem, out . println £ "Lese Toolbar" ) ; 

readTool- 

bar (lgcPath) ; 

break ; 

100 ) 

if 

(token. sval . equals ("MENU") ) { 

Sy- 
stem, out . println ( "Lese Menue" ) ; 
105 readMenu ( ) ; 

break ; 

> 

if 

(token. sval. equals ( "ANALYSIS BAR" ) 
110 ) { 

Sy- 
stem, out . println ( "Lese Analyse- 
Bar") ; 

readAnalyse ( ) ; 
115 brea k ; 

) 

if 

(token. sval . equals ( "SHORTCUTS" ) ) 
{ 

120 Sy- 
stem, out . println ( "Lese Short- 
cuts") ; 

readShorts ( ) ; 
break; 
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10 



} 

if 

(token. sval. equals ( "ACCELERATOR" ) 
) { 

Sy- 
stem, out . println ( "Lese Accelera- 
tor") ; 

readAccel ( ) ; 
break; 

} 

default : 



/ /c=token . nextToken ( ) ; 
//System. out . println ( "IN 
65 der TOOLBAR " + c ) ; 
} 

} catch (IOException e) { 
e . printStackTrace ( ) ; 

} 

70 //System. out . println { "Fertig 

Toolbar") ; 
) 



} 



15 



20 



in . close ( ) ; 
System, out . flush { ) ; 
System, out . println ( "EINLESEN 
DER DAT EI " +configFile + " 
FERTIG! ") ; 

//und wichtig fiir die Anzei- 
ge : 

setLayer ( ) ; 
setAttributNames ( ) ; 
} catch 

25 ( FileNotFoundException e) { 

System, err . println { con- 
figFile + " is not found"); 

J catch (IOException e) { 
e . printStackTrace ( } ; 



30 



35 



40 



45 



50 



55 



60 



} 



} 



private void readToolbar ( String 
lgcPath) { 

int c = ' { ' ; 
gob jekte . clear ( ) ; 
//System, out . println ( " Jetzt 
kommt die Toolbar") ; 
try { 

while (c != * } ' ) { 
switch 
(c=token . nextToken ( ) ) { 

case StreamTokeni- 
zer . TT_WORD: 

if 

(token. sval. equals ("NODE") ) { 

//System. out . println ( "Lese Kno- 
ten" ) ; 

readNode (lgcPath) ; 
break; 

} 

if 

(token. sval. equals ("EDGE") ) { 

//System. out . println ( "Lese Kan- 
te") ; 

readEdge (lgcPath) ; 
break; 

) 

default: 

) 



75 private void readNode { String 
lgcPath) { 

int c = * { ' ; 

String typname = new 
String ( ) ; 

80 String image = new String ( ) ; 

Vector ecken = new Vector () ; 
Vector konnektoren = new Vec- 
tor ( ) ; 

Vector konnektorNamen = new 
85 Vector (); 

Attribute attribute = new 
StandardAttribute ( ) ; 

Color color — new Co- 
lor (255, 255, 255 ) ; 
90 //System. out. println ( "Ein 

Knoten") ; 
try { 

while (c != * ) 1 ) { 
switch ( c) { 
95 case StreamTokeni- 

zer . TT_WORD: 

// Wird nicht mehr be- 

notigt 

// if 

100 (token. sval. equals ("TYPE") ) { 

// 

c=token . nextToken ( ) ; 

// Sy- 
stem, out .println ( "Lese TYPE" + 
105 token. sval); 

// break; 

// ) 
if 

(token. sval . equals ( "NAME") ) { 

110 

c=token . nextToken ( ) ; 

typname = new 
String ( token . sval ) ; 

// Sy- 
stem, out . println { "Lese NAME" + 
typname) ; 

break; 

) 

if 

12 0 (token. sval . equals ( "ATTRIBUTES" ) ) 
{ 

attribute = new 
StandardAttribute ( ) ; 



115 
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while 

( ( c=token. nextToken ( ) ) != 'JM { 

String aname = 65 
new String (token . sval ) ; 

c = to- 
ken. nextToken { ) ; 

String wert = new 
String ( token - sval ) ; 70 

attribu- 
te - addAttribut ( aname, wert , true ) ; 

attributNa- 
men - put ( aname , aname ) ; 

// Sy- 75 
stem, out . print In ( "Lese Attribut- 
te" + attribute) ; 

} 



break ; 

) 

if 

(token. sval . equals ( "IMAGE" ) ) { 



80 



85 



c=token . nextToken { ) ; 

image = new 
String (token. sval) ; 

// Sy- 
stem, out . print In ("Lese IMAGE" + 
image) ; 90 

break; 

} 

if 

(token. sval . equals ( " FI LLEDPOLYGON 
")) { 95 

ek- 

ken. removeAllElements ( ) ; 

int x,y; 
while 

( (c=token. nextToken () ) !='}') { 100 

x = 

( int ) token . nval ; 

c=token . nextToken ( ) ; 

y = 105 

( int ) token . nval ; 

ek- 

ken. addElement (new Point (x,y)); 

// Sy- 
stem, out. println ( "Lese POLYGON" + 110 
ecken) ; 

} 

// jetzt sollten 
alle Daten da sein, und es 

// kann ein Knoten- 115 
prototyp erzeugt werden. 

GraphObjekt knoten = 
new FilledPolygonKnoten ( typname , 



attribute) ; 

kno- 
ten . setColor ( color ) ; 

// Sy- 
stem, out .println ( "Setze Farbe " + 
color) ; 

/ / Erzeuge Button 
mit Werzeug fur Werkzeugleiste 

ToolButton b = new 
ToolButton (lgcPath + "images/" + 
image, 

typname, 

new KnotenTool (editor, typname) , 

editor . getToolbar ( ) ) ; 

edi- 
tor . getToolbar ( ) . addToolButton (b) 

// Eintrag in die 

Hashtabelle 

gob j ek- 
te , put ( typname , knoten ) ; 

// Sy- 
stem, out .println ( "In Hashtabelle : 
" + gobjekte) ; 

break; 

} 

if 

(token. sval .equals ( "POLYGON") ) { 

ek- 

ken . removeAllElements ( ) ; 

int x,y; 
while 

( (c=token. nextToken () ) != * ) 1 ) { 

x = 

(int ) token . nval ; 
c=token . nextToken ( ) ; 

y = 

( int ) token . nval; 

ek- 

ken. addElement (new Point (x,y)); 

// Sy- 
stem, out .println ( "Lese POLYGON" + 
ecken) ; 

) 

// jetzt sollten 
alle Daten da sein, und es 

// kann ein Knoten- 
prototyp erzeugt werden. 

GraphObjekt knoten = 
new PolygonKnoten ( typname, 



ecken, 

konnektoren, 



120 ecken, 



konnektoren, 



konnektorNamen , 



konnektorNamen, 
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attribute ) ; 

kno- 

ten.setColor (color) ; 
5 // Sy- 

stem, out . println ( "Setze Farbe " + 
color) ; 

// Erzeuge Button 
mit Werzeug fur Werkzeugleis te 
10 // Der Button greift 

uber den typnamen auf den richti- 
gen 

// Knoten zu. 
ToolButton b = new 
15 ToolButton (lgcPath + "images/" + 
image , 



20 



25 



30 



35 



40 



45 



50 



55 



60 



typname, 

new KnotenTool (editor, typname) , 

editor . getToolbar ( ) ) ; 

edi- 
tor . getToolbar ( ) . addToolButton (b) 
* 

// Eintrag in die 

Hashtabelle 

gob j ek- 
te . put ( typname , knoten ) ; 

//System. out . println ( "In Hashta- 
belle: " + gobjekte); 

break; 

} 

if 

(token. sval . equals ( "FILLEDOVAL" ) ) 

{ 

int breite=10; 
int hoehe=10 ; 
while 

( (c-token. nextToken <) ) !=*)') ( 

breite - 

( int ) token . nval ; 

c=token . nextToken ( ) ; 

hoehe = 

(int ) token . nval ; 

// Sy- 
stem, out .println ("Lese 0VAL_FILL" 
+ token . nval ) ; 

} 

// jetzt sollten 
alle Daten da sein, und es 

// kann ein Knoten- 
prototyp erzeugt werden. 

GraphObjekt knoten 
= new FilledOval Knoten ( typname, 

hoehe, 

breite , 



konnektoren, 

65 

konnektorNamen, 
attribute) ; 

kno- 

70 ten . setColor ( color ) ; 

// Sy- 
stem, out . println ( "Setze Farbe " + 
color) ; 

// Erzeuge Button 
75 mit Werzeug fur Werkzeugleiste 

ToolButton b = new 
ToolButton (lgcPath + "images/" + 
image, 

80 typname, 

new KnotenTool ( editor , typname ) , 



85 



90 



95 



editor . getToolbar { ) ) ; 

edi- 
tor . getToolbar ( ) . addToolButton (b) 

// Eintrag in die 

Hashtabelle 

gob j ek- 
te.put (typname, knoten) ; 

//System. out .println ("In Hashta- 
belle: " + gobjekte); 

break; 



} 

if 

(token. sval. equals ("OVAL") ) { 
100 int breite=10; 

int hoehe=10; 
while 

( (c-token. nextToken () ) !='}') ( 

breite = 

105 (int ) token . nval ; 

c=token . nextToken ( ) ; 

hoehe = 

(int) token. nval ; 
110 // Sy- 

stem, out . println ( "Lese OVAL" + 
token . nval ) ; 

) 

// jetzt sollten 
115 alle Daten da sein, und es 

/ / kann ein Knoten- 
prototyp erzeugt werden. 

GraphObjekt knoten 
— new OvalKnoten ( typname, 

120 

hoehe, 
breite, 
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konnektoren, 
konnektorNamen, 
attribute) ; 

kno- 

ten . setColor ( color ) ; 

// Sy- 
stem, out .println { "Setze Farbe " + 
color) ; 

// Erzeuge Button 
mit Werzeug fur Werkzeugleiste 

ToolButton b = new 
ToolButton (lgcPath + "images/" + 
image, 

typname, 

new KnotenTool ( editor , typname ) , 

editor . getToolbar ( ) ) ; 

edi- 
tor . getToolbar { ) . addToolButton (b) 

* 

// Eintrag in die 

Hashtabelle 

gob jek- 
te . put ( typname , knoten ) ; 

//System, out . println ( "In Hashta- 
belle: " + gobjekte) ; 

break; 

1 

if 

(token. sval. equals ( "CONNECTORS") ) 
t 

konnekto- 
ren . removeAllElements { ) ; 

int x,y; 
String name; 
while 

( (c^token. nextToken () ) != '}') { 

x = 

( int ) token . nval ; 

c— token . nextToken ( ) ; 

y = 

(int) token. nval; 

c=token. nextToken ( ) ; 

name = to- 
ken . sval ; 

konnekto- 
ren . addElement (new Point (x,y)); 

konnektorNa- 
men . addElement ( name ) ; 

// Sy- 
stem, out .println ( "Lese Konnekto- 
ren" + konnektoren) ; 
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// Sy- 
stem, out . println ( "Die Namen: " + 
konnektorNamen) ; 

) 

break ; 

) 

if 

( token. sval. equals ("COLOR") ) { 

c=token . nextToken ( ) ; 

//System. out. println { "Lese COLOR" 
4 token. nval); 

int r = 
(int ) token . nval ; 

c=token. nextToken ( ) ; 

//System, out . println ( "Lese COLOR" 
+ token . nval ) ; 

int g - 
(int ) token . nval ; 



85 c=token . nextToken () ; 



//System, out. println ("Lese COLOR" 
+ token . nval ) ; 

int b = 
(int ) token . nval ; 

color = new Co- 
lor < r , g, b) ; 

break; 
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100 



105 



110 



115 



120 



J 

default : 
} / /switch 

c=token . nextToken ( ) ; 

// Sy- 
stem, out . println ( "NAECHSTES 
TOKEN " + token. sval); 
) //while 

//c=token . nextToken ( ) ; 
} catch (lOException e) { 
e .printStackTrace ( ) ; 

} 

// System. out . println ( "Bende 
readNode") ; 

} / /readNode 



private void readEdge ( String 
lgcPath) [ 

// System. out . println ( "Eine 
Kante") ; 

int c = ' { • ; 

String typname = new 
String ( ) ; 

String image = new String ( ) ; 

Attribute attribute = new 
StandardAttribute ( ) ; 
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Color color = new Co- 
lor (255, 255 , 255 ) ; 
try { 

while (c ! = • ) ' ) { 
5 switch (c) { 

case StreamTokeni- 
zer . TT_WORD : 

if 

10 ( token . sval . equals ( "NAME" ) ) ( 



23 



15 



20 



25 



c=token . nextToken { ) ; 

typname = new 
String (token . sval ) ; 

// Sy- 
stem, out . println ( "Lese NAME " + 
typname) ; 

break; 

} 

if 

(token . sval . equals ("ATTRIBUTES") ) 

attribute = new 
StandardAttribute ( ) ; 

while 

( (c-token . nextToken (} ) != '}•) { 

String aname =. 
new String (token. sval) ; 

c - to- 

30 ken . nextToken () ; 

String wert = new 
String (token . sval ) ; 

attribu- 
te. addAttribut (aname, wert , true) ; 
35 attributNa- 
men . put ( aname , aname ) ; 

// Sy- 
stem, out . println ( "Lese Attribut- 
te" + attribute) ; 
40 j 



break; 
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c=token . nextToken ( ) ; 

winkel = 

(int ) token . nval ; 

// Sy- 
stem, out .println ( "Lese Arrow" + 
radius+ winkel); 

} 

// jetzt sollten 
alle Daten da sein, und es 

// kann ein Kanten- 
prototyp erzeugt werden. 

GraphObjekt kante = 
new PfeilKante (typname, 



radius , 
80 winkel , 
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} 

if 



105 



4 5 (token, sval . equals ( "IMAGE" ) ) { 



50 



c-token . nextToken ( ) ; 

image — new 
String (token. sval) ; 

// Sy- 
stem, out .println ( "Lese IMAGE" + 
image) ; 

break; 

) 

if 

(token, sval . equals ("ARROW" ) ) { 

int radius - 10; 
int winkel = 10; 
while 

60 ( (c=token .nextToken {) ) != •)■) { 

radius = 

(int) token. nval; 
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attribute) ; 

kan- 
te. setColor (color ) ; 

// Sy- 
stem, out . println ( "Setze Farbe " + 
color) ; 

// Erzeuge Button 
mit Werzeug ftir Werkzeugleiste 

ToolButton b = new 
ToolButton (lgcPath + "images/" + 
image, 

typname, 

new KantenTool (editor , typname) , 

editor . getToolbar ( ) ) ; 

edi- 
tor .getToolbar ( ) . addToolButton (b) 

// Eintrag in die 

Hashtabelle 

gob jek- 
te . put ( typname , kante ) ; 

/ /System. out .println ("In Hashta- 
belle: " + gobjekte) ; 

break; 

} 

if 

(token . sval . equals ( "POINT" ) ) { 

int durch = 10 ; 
while 

(( c=token . nextToken () ) != 1 J 1 ) ( 

durch = 

(int) token . nval ; 

// Sy- 
stem, out . println ( "Lese Point" + 
durch) ; 

] 

// jetzt sollten 
alle Daten da sein, und es 
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// kann ein Kanten- 
prototyp erzeugt werden. 

GraphObjekt kante = 
new KreisKante (typname, 

5 

durch, 
attribute) ; 

kan- 

10 te - setColor ( color ) ; 

// Sy- 
stem . out . println ( "Setze Farbe " + 
color) ; 

// Erzeuge Button 
15 mit Werzeug fiir Werkzeugleiste 

ToolButton b = new 
ToolButton ( lgcPath + "images/" + 
image , 

20 typname, 
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35 



new KantenTool ( editor , typname ) , 

editor . getToolbar { ) ) ; 

edi- 
tor . getToolbar () . addToolButton ( b ) 

// Eintrag in die 

Hashtabelle 

gob jek- 
te . put ( typname , kante ) ; 

/ / System. out .println ( "In Hashta- 
belle: " + gobjekte) ; 

break ; 



40 



45 



} 

if 

{token. sval . equals { "NOEND" ) ) { 

while 

( (c=token. nextToken () ) !='}') { 

// durch - 
( int ) token . nval ; 

// Sy- 
stem, out . println { "Lese Point" + 
durch) ; 

} 

// jetzt sollten 
50 alle Da ten da sein, und es 

// kann ein Kanten- 
prototyp erzeugt werden . 

GraphObjekt kante = 
new StandardKante (typname, 

55 

attribute) ; 

kan- 
te . setColor ( color) ; 

// Sy- 

60 stem. out . println ( "Setze Farbe " + 
color) ; 
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// Erzeuge Button 
mit Werzeug fur Werkzeugleiste 

ToolButton b = new 
ToolButton ( lgcPath + "images/" + 
image , 

typname, 

new KantenTool (editor , typname ) , 

editor . getToolbar ( ) ) ; 

edi- 
tor . getToolbar ( ) . addToolButton (b) 

r 

I / Eintrag in die 

Hashtabelle 

gob j ek- 
te . put (typname , kante ) ; 

/ /System. out . println ( "In Hashta- 
belle: " + gobjekte); 

break ; 



if 

( token . sval . equals ( "SIZE" ) ) { 

c=token . nextToken ( ) ; 

Sy- 
stem, out . println ( "Lese SIZE" + 
token . nval ) ; 

break; 

} 

if 

(token. sval . equals ( "COLOR" ) ) ( 

//System. out . println ( "Lese COLOR" 
+ token . nval ) ; 

c=token . nextToken ( ) ; 

int r = 
( int ) token . nval ; 

c^token . nextToken ( ) ; 

//System. out .println ( "Lese COLOR" 
+ token . nval ) ; 

int g = 
{ int) token . nval ; 

c=token . nextToken ( ) ; 

//System. out . println ( "Lese COLOR" 
+ token . nval ) ; 

int b = 
( int ) token . nval ; 

color = new Co- 
lor ( r , g, b) ; 

// Sy- 
stem, out . println ( "Gelesene Farbe : 
" + color) ; 



WO 00/14661 



PCT/DE99/02753 



25 



break; 



} 



default: 
} //switch 
5 c=token . nextToken ( ) ; 

// Sy- 
stem, out . println { "NAECHSTES 
TOKEN" + token. sval); 
} //while 
10 //c=token . nextToken {) ; 

} catch (IOException e) { 
e , prints tackTr ace { ) ; 

) 

// System. out . println ( "Bende 
15 readEdge"); 

} //readEdge 



20 private void readMenu ( ) { 
tools . clear ( ) ; 
int c = ' { 1 ; 
try { 
while 

25 { (c=token. nextToken () ) !-'}•) { 
//c=token . nextToken ( ) ; 
String namen = to- 
ken . sval ; 

System. out . println ( " Jetzt 
3 0 kommt das Menu"+ namen); 

c = token . nextToken () ; 
String aufruf = to- 
ken . sval ; 

System. out . println ( "Jetzt 
35 kommt das Menu"+ aufruf) ; 

tools . put (new 
String (namen) , new 
String (aufruf) ) ; 
} 

40 } catch (IOException e) { 

e . printStackTrace ( ) ; 

} 
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// private void uebergebe 
(String mpunkt , String 
iconl, String icon2) { 

// public void addBut- 
ton ( String menuePunkt, String 
imagel, String image2 ) 

private void uebergebe ( String 
auswahl , String name, String style, 
int size) { 

int stylelnt = 0; 
switch ( style . charAt ( 0 )) ( 
case * B ' : 



stylelnt 
break; 

case ' P ' : 
stylelnt 
break; 

case ' I ' : 
stylelnt 
break; 

default : 
stylelnt 



= Font . BOLD; 



= Font . PLAIN ; 



= Font. ITALIC ; 



= Font . PLAIN ; 



Font font = new Font (name, 
stylelnt, size) ; 

switch ( auswahl . charAt (0) ) { 
case 1 M ' : 
edi- 
tor . getMenueleiste ( ) . set Font ( font 
) ; 

break ; 
case 1 P 1 : 

//noch zu Implementiern 
break; 
case ' S ' : 
edi- 
tor . getStatusleiste ( ) . set Font ( f on 
t) ; 

break ; 



) 



} 
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) 



private void readAnalyse ( ) { 
System. out . println ( "Jetzt 
kommt die Analyse"); 
} 

private void readShorts ( ) { 
System, out . println ( "Jetzt 
kommt die Shortcut"); 
) 

private void readAccel ( ) ( 

System. out . println ( "Jetzt 
kommen die Accelerators") ; 



private void uebergebe ( String 
105 auswahl, int r,int g,int b) { 

if (auswahl. equals ("PAPER") ) { 
edi- 
tor . getZeichenf laeche ( ) . setBackgr 
ound(new Color ( r, g, b) ) ; 
110 } 

if (auswahl. equals ("GRID") ) ( 
//noch zu implementiern 

} 

if 

115 ( auswahl . equals ( "MENUBGC" ) ) { 
// edi- 
tor . getMenueleiste ( ) . setBackgroun 
d{new Color(r,g,b) ) ; 

} 

120 if 

{ auswahl. equals ("MENUFGC") ) { 
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// menubar . setForeground (new 
Color ( r, g, b) ) ; 
} 

if 

5 ( auswahl . equals { " STATUS BGC" ) ) { 
edi- 
tor . getStatusleiste ( ) . setBackgrou 
nd (new Color ( r, g, b) ) ; 
) 

10 if 

(auswahl . equals ( "STATUS FGC" ) ) { 

edi- 
tor . getStatusleiste ( ) . setForegrou 
nd(new Color ( r, g, b )) ; 
15 } 
if 

( auswahl . equals ( "TOOLBGC" ) ) { 

edi- 
tor . getToolbar ( ) . setBackground (ne 
20 w Color (r, g,b) ) ; 
) 

if 

(auswahl . equals ( "TOOLFGC" } ) { 
edi- 

2 5 tor . getToolbar ( ) .setForeground 
(new Color ( r, g, b )) ; 
} 

if 

(auswahl . equals ( " SHORTCUT BGC*' ) ) { 
30 edi- 
tor. getShortcutleiste ( ) . setBackgr 
ound(new Color ( r, g, b) ) ; 
> 

if 

35 ( auswahl . equals ( "SHORTCUT FGC" ) ) { 
edi- 
tor . getShortcutleiste { ) . setForegr 
ound (new Color ( r, g, b )) ; 
) 

40 } 

/ + + 

* Liefert eine Kopie eines 
GraphOb jektes 

45 * zuriick. 

*/ 

public GraphObjekt getOb- 
jekt (String name) ( 
if 

50 (gob jekte . containsKey (name) ) { 
GraphObjekt vater = 
( GraphOb j ekt ) gob j ekte . get ( name ) ; 
return 

( GraphOb j ekt ) vater . copy ( ) ; 
55 ) else { 

return null; 

} 

) 

60 /** 

* Diese Methode fugt alle an- 
zeigbaren ObjekteTypen in die 



* Hashtable der Klasse Gra- 
phObjekt ein, 

65 * -> alle Ob j ekte werden ange- 

zeigt . 
*/ 

public void setLayer ( ) { 
Hashtable alle = new Has- 
7 0 htable ( gob j ekte . size ( ) , 1 . Of ) ; 

Enumeration e = gobjek- 
te . keys ( ) ; 

while (e . hasMoreElements ( ) ) 

I 

"75 String key = 

(String) e . nextElement { ) ; 

alle . put ( key, new 
String ( key) ) ; 
) 

80 GraphObjekt . toShow = alle; 

I 

/ ■*■ + 

* Liefert alle anzeigbaren 
85 Layers zuriick. 

*/ 

public Enumeration getLayers() 

{ 

return gob jekte . keys () ; 

90 ) 

/** 

* Liefert die maximale Anzahl 
der Layers zuriick. 

95 */ 

public int countLayers ( ) ( 
return gobj ekte . size () ; 

) 

100 /** 

* Diese Methode fiigt alle an- 
zeigbaren AttributNamenn in die 

* Hashtable der Klasse Attri- 
bute ein, 

105 * -> alle Attribute werden an- 

gezeigt . 
*/ 

public void setAttributNames ( ) 

{ 

110 Hashtable alle = new Has- 

htable (attributNamen .size(),1.0f) 
; 

Enumeration e = attributNa- 
men . keys ( ) ; 
115 while ( e . hasMoreElements () ) 

{ 

String key = 
(String) e . nextElement ( ) ; 

alle . put ( key, new 
120 String (key) } ; 
} 

Attribute . toShow = alle; 

) 
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/** 

* Liefert alle anzeigbaren 
AttributNamen zuriick . 

*/ 

public Enumeration getAttri- 
butNames ( ) { 

return attributNamen . keys ( ) ; 

) 

/ * 

* Liefert die maximale Anzahl 
der Attribute zuriick. 

*/ 

public int countAttributNa- 
mes ( ) { 

return attributNamen. size { ] ; 

} 

* Fugt einen Attribut namen 
in die 



* Hashtabel ein. 
*/ 

public void addAttributName ( 
2 5 String name J { 

attributNamen . put (new 
String (name) , new String (name )) ; 
} 

30 / + * 

■*■ 

*/ 

public Hashtable getTools ( ) { 
return tools; 

35 } 

// public String getConf igFile ( ) 

( 

// return configFile; 
40 // } 



} 



2. Datei "load" 



package commands; 

import etc. *; 
import java.util.*; 
import java.awt.*; 
import java.io.*; 
import interfaces.*; 

/ + + 

* Ladt einen Graphen aus einer 
.lgf Datei. 
*/ 

public class Load extends Befehl 

{ 

Vector undo; 

public Load (GraphEditor edi- 
tor) { 

super (editor ) ; 
undo=new Vector ( ) ; 
help = 

"<filename.lgf / .lgc/. lgt>" ; 
) 



public void ausfuehren ( String [ ] 
param) { 

//System. out .print In (param) ; 
int anzahl = param. length; 
switch (anzahl) { 

case 0 : // bei keinem Ar- 
gument tun wir nichts . 

break ; 

case 1 : // bei einen Ar- 
gument wird erst nachgeschaut ! 



80 



if 



(param[0] . endsWith ( " . lgc") || 

pa- 
ram [ 0 ] . endsWith (".lgf") II 

pa— 

85 ram(0] .endsWith {".lgt") ) { 

// wir wurden 
von der CommandoZeile aufgerufen 

File file = new 

File (param[ 0] ) ; 
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//System. out . println ( "Der Pfad : 
" + file.getParent ()) ; 

//System, out . println ( "Der Name : 
" + f ile .getName ( ) ) ; 

prue- 

fe (file.getParent ()+"/", file.getN 
ame ( ) ) ; 

} else { 
//nothing 

) 

break ; 

//zuviel Parame- 
break; 



default 



ter 



} //switch 



} 



public void ausfuehren ( String 
110 param) { 
edi- 
tor . gets tatus lei s te ( ) . show ( "Load. 



115 ( (Component) editor) . setCursor (Cur 
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sor . getPredef inedCursor (Cursor . WA 
IT_CURSOR) ) ; 

FileDialog fd = new FileDia- 
log ( { Frame) editor, null , FileDialog 
. LOAD) ; 

// das hat leider noch keine 
Auswirkungen in Windows und Sola- 
ris 

// ab 1.1.6 gehts doch 



f d . setDi rectory (System. getPropert 
y ("user.dir") ) ; 
// das schon 

fd. set File ( "noname. Igf " ) ; 
15 FilenameFilter filter = new 

lgFilter () ; 

fd. set FilenameFilter ( filter) ; 

f d . show ( ) ; 

String dir = 
20 f d . getDirectory ( ) ; 

String file = fd. getFile ( ) ; 

// fd. getFile () liefert null 
bei Abbruch! 

if (file* == null) { 
2 5 // nichts zu tun 
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( (Component ) editor ) . setCursor ( Cur 
sor . getDef aultCursor ( ) ) ; 
return; 
} else { 
// laden 

//System. out . println ( f d . get Direct 
ory() ) ; 



//System. out . println ( fd. getFile ( ) 
) ; 

Vector ge- 
loescht=editor , getGraph ( ) . removeA 
40 11(); 

pruef e (dir, file) ; 
edi- 
tor . getGraph ( ) . setChanged ( false ) ; 
editor . setAuswahl (new Vec- 

4 5 tor()); 

Vector lastCommands = edi- 
tor . getLastCommands ( ) ; 

if (lastCommands . size ( ) < 

10) ( 

50 lastCom- 
mands . addElement ( this ) ; 
} else { 
lastCom- 
mands . removeElementAt (0) ; 

5 5 lastCom- 

mands . addElement ( this ) ; 
) 

if (undo. size ( ) < 10) { 

60 undo . addElement (geloescht) ; 
) else { 

undo . removeElementAt ( 0 ) ; 
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75 ); 
} 



undo . addElement ( geloescht ) ; 
} 

)//else 

edi- 
tor . getZeichenf laeche ( ) . drawBuf f e 
r ( editor . getGraph { ) ) ; 

( (Component ) editor) . setCursor ( Cur 
sor . getDef aultCursor ( ) ) ; 

edi- 
tor . getStatusleiste ( ) . show ( "Done" 



80 



/; 



gig 



Macht Datei laden riickgan- 



/ 
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public void undo ( ) { 
edi- 
tor . getStatusleiste ( ) . show ( "Undo : 
Load ..."); 

( ( Component ) editor ) . setCursor ( Cur 
sor. getPredef inedCursor (Cursor . WA 
IT_CURSOR) ) ; 

if { ! undo . isEmpty ( ) ) { 
Vector insert = 
(Vector ) undo . lastElement ( ) ; 
if (insert null) ( 
edi- 
tor . getGraph ( ) . removeAll ( ) 

edi- 
tor . getGraph ( ) .add(insert) 

insert . removeAHElements ( ) 
1 

undo . removeElement (undo . lastEleme 
nt ( ) ) ; 
} 

edi- 
tor . getZeichenf laeche { ) . drawBuf f e 
r (editor . getGraph ( ) ) ; 

edi- 
tor . getGraph ( ) . setChanged (true ) ; 

edi- 
tor . getStatusleiste ( ) . show ( "Done" 
) ; 

( (Component ) editor ) . setCursor (Cur 
sor . getDef aultCursor ( ) ) ; 
) //undo 

y + * 

* Wiederholt Datei laden.. 
*/ 

public void redo ( ) { 

edi- 
tor . getStatusleiste ( ) . show ( "Redo : 
Load ..."); 

aus f uehren ( ) ; 
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)// redo 
I * + 

* Diese Klasse wird leider 
5 nicht an 

* die Windows bzw Solaris Kom- 
ponente 

* weitergereicht . 



7 
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class lgFilter implements Fi- 
lenameFilter { 

public boolean accept (File 
dir, String name) { 
return ( na- 
15 me. endsWith (".lgf" ) I I 

na- 
me . endsWith ( " . lgc" ) | I 

na- 
me . endsWith ( " . lgt" ) ); 



20 



1 

} 



25 



30 



35 



40 



* Diese Methode uberpruft, ob 
die richtige 

* Konf igurationsdatei geladen 
ist, ansonsten wird 

* versucht die richtige zu la- 
den. (->Editor zurucksetzen) 

* Dannach wird die gewunschte 
.lgt oder . lgf Datei 

* geladen. 

private void pruefe (String 
pfad, String datei) { 

Einstellungen settings= edi- 
tor . getEinstellungen ( ) ; 

if ( datei. endsWith(" .lgc" ) ) { 
//System, out . print In ( "eine 
lgc Datei") ; 

File f - new File (pfad + 
datei ) ; 

if (f.exists(J) { 

settings . appName = Ein- 
stellungen . format (datei ) ; 

settings . fileName=" "; 
settings . frameName — set- 
tings . fileName+ " " 
+settings . appName + " " 
+settings . copyright; 

settings . configFile = new 
String (datei ) ; 

settings . IgcPath = new 
String (pfad) ; 

//wir Starten den Editor 

neu 

editor . start ( ) ; 
) else { 

System. err .println ( "File 
not found : "+ settings . IgcPath + 
60 datei) ; 

J 
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} else if 
(datei. endsWith (".lgf") ) ( 

/ /System. out .println ( "eine 
lgf Datei") ; 

File f = new File (pfad + 
datei) ; 

if (f .exists ( ) ) { 

settings . fileName = da- 
tei ; 

// wir holen uns noch den 
namen des .lgc Files: 

String config — edi- 
tor . getDateischnittstelle ( ) . getCo 
nf ig (pf ad + datei); 

//System. out . println ( "Der 
neue Name der Lgc datei " + con- 
fig) ; 

f = new 

File ( settings . IgcPath + config); 
if (f . exists ( ) ) ( 

// ist diese lgc Datei 
schon geladen? 

if 

( settings . configFile . equals ( conf i 
g) ) { 

//wir muessen nur die 
lgf Datei laden 

edi- 
tor . getDateischnittstelle ( ) . load ( 
pfad, datei, editor . getGraph ( ) ) ; 

settings . frameName = 
settings . f ileName+ " " 
+settings . appName + " " 
+settings . copyright; 

( (Frame) editor) . set- 
Title (settings . frameName) ; 
) else { 

// wir miissen auch 
die Konnf igurationsdatei laden 

s ettings . appName = 
Einstellungen . format ( config) ; 

settings . configFile = 
new String ( conf ig) ; 

settings . frameName = 
settings . fileName+ " " 
+settings . appName + " " 
♦settings . copyright; 

//wir Starten den 

Editor neu 

editor . start ( ) ; 

edi- 
tor . getDateischnittstelle ( ) , load ( 
pfad, datei , editor . getGraph ( ) ) ; 
} 

} else ( 
Sy- 
stem, err . println ( "File not found 
: " + settings . IgcPath + config); 

) 

} else t 

System. err . println ( "File 
not found : " + pfad + datei); 
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} 

//start ( ) ; 
} else if 
< datei. endsWith (" .lgt") ) { 
5 / /System. out .println ( "eine 

lgt Datei") ; 

File f = new File (pf ad + 
datei ) ; 

if (f . exists ( ) ) { 
10 settings . fileName = da- 

tei ; 

settings . frameName = set- 
tings . fileName+ " " 
-t-settings . appName + " " 
15 +settings . copyright ; 

// wir holen uns noch den 
namen des . lgc Files : 

//String config = edi- 
tor . getDateischnittstelle ( ) . getCo 
20 nfig{pfad + datei); 

//System. out . println ("Der 
neue Name der Lgc datei " + con- 
fig) ; 

//f - new 
25 File ( settings . lgcPath + config); 

//if (f. exists { ) ) < 

/ / ist diese lgc Datei 
schon geladen? 

//if 

30 ( settings . configFile . equals (confi 

g) ) { 

//wir muessen nur die 
lgt Datei laden und interpretie- 
ren 

3 5 Lgt Interpreter inter- 

preter=editor . getlnterpreter ( ) ; 

//System. out . println ( "Der Inter- 
preter : " + interpreter) ; 

4 0 if (interpreter =- 

null) { 

interpreter = new 
Lgtlnterpreter ( editor , pf ad + da- 
tei) ; 

4 5 edi- 
tor . set Interpreter (interpreter) ; 

interpre- 
ter . start ( ) ; 

) else { 

100 

3. Datei "toolbar" 

package rami; 

105 import java.awt. *; 

import java . awt . event . * ; 

import etc.*; 
import tools . * ; 



30 

50 interpre- 
ter . set File (pf ad + datei ) ; 
1 

//Dateischnittstelle ( ) . load (pf ad, 
55 datei , editor . getGraph ()) ; 

//settings . frameName 
= settings . appName + " " + set- 
tings . fileName ; 

// ( (Frame) editor) . 
60 setTitle (settings . frameName ) ; 

// } else { 

// wir mussen auch 
die Konnf igurationsdatei laden 

// settings . appName = 
65 Eins tellungen . format (config) ; 

//settings . configFile 
- new String ( config ) ; 

// settings . frameName 
= settings . appName + " " + set- 
7 0 tings . fileName ; 

//wir Starten den 

Editor neu 

//editor . s tart () ; 
/ / Lgtlnterpreter in- 
75 terpreter — new Lgtlnterpre- 
ter (editor , pf ad + datei); 

// edi- 
tor, set Interpreter (interpreter) ; 
// interpre- 
80 ter.startO; 

// } 
//} else { 
// Sy- 
stem, err . println ( "File not found 
85 : " + settings . lgcPath + .config) ; 

//) 
} else { 

System. err . println ( "File 
not found : " + pfad + datei) ; 
90 } 

} else { 

System. err . println ( "usage : 
java LoGraph2 <path to config- 
files> AND <file.lgc> OR 
95 <file.lgf> OR <f ile . lgt>" } ; 
) 

} 

} 



110 

/ + + 

* liber das aktuelle Tool der 
Toolbar werden die 

* Maus Aktionen des Benutzers an 
115 den Graphen weitergegeben . 
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* Die Toolbar ermoglicht das 
hinzufiigen und entfernen 

* von ToolButtons, und deren zu- 
gehorigen ActionListener. 65 

*/ 

public class Toolbar extends Pa- 
nel { 

GraphEditor editor; 

Tool currentTool; 7 0 

ToolButton currentButton; 

int borderSize = 4; 

j -*• * 

* Der Konstruktor erzeugt das 
AuswahlTool, 7 5 

* da dieses immer vorhanden 
sein sollte. 

*/ 

public Toolbar { GraphEditor edi- 
tor) { 80 

this. editor = editor; 

setLayout (new BarLay- 
out ( Bar Layout . VERTIKAL, 2 ) ) ; 

setBackgro- 
und ( editor . getEinstellungen ( ) . too 8 5 
IbarBgCo) ; 

// eine kleine Lucke 

add (new Space ( 5 , 24 ) ) ; 

ToolButton b = new ToolBut- 90 
ton (editor . getEinstellungen ( ) . lgc 
Path + 



int w = getSize() .width- 
insets . left-insets .right ; 

int h - getSize (). height- 
insets . top- insets . bottom; 

g . setColor (editor . getEinstellunge 
n ( ) . toolbarBgCo ) ; 

for {int i = 0; i<borderSize ; 
i++) i 

g ,draw3DRect ( i + insets . lef t , i+inse 
ts . top, 

w-2*i-l, h- 
2*i-l, i<borderSize/2) ; 



} 



} 



/ + + 

* Fugt einen ToolButton hinzu. 
*/ 

public void addToolBut- 
ton (ToolButton button) { 
add (button) ; 

} 

/** 

* Entfernt einen ToolButton. 
*/ 

public void deleteTooleBut- 
ton (ToolButton button) { 
) 



"images / auswahl . gif " , 
"Select", 



95 



new AuswahlTool ( editor ) , this ) ; 

setCurrentTool (b . getTool ( ) ) ; 
setCurrentButton (b ) ; 100 
add (b) ; 

add(new Space ( 5, 24 ) ) ; 

} 

105 

public Insets getlnsets ( ) { 
Insets insets = 
(Insets) ( super . getlnsets ( ) ) .clone 
() ; 

insets. top += borderSize; 110 

insets. left +— 
(borderSize+2 ) ; 

insets . bottom += borderSize; 

insets . right += 
(borderSize+2 ) ; 115 

return insets; 

} 

public void paint (Graphics g) { 

super . paint (g) ; 120 
Insets insets = su- 
per . getlnsets ( ) ; 



/ + * 

* Setzt das aktuelle Tool; 

* wird normalerweise von den 
ToolButtons aufgerufen. 

*/ 

public void setCurrentTool (Tool 
currentTool) { 

this . currentTool - current- 
Tool; 

this . currentTool . reset ( ) ; 

} 



/ 



* Setzt den aktuellen Button, 
damit der nachste 

* aktuelle Butten ihn zurtick- 
setzen kann. 

*/ 

public void setCurrentBut- 
ton (ToolButton currentButton) { 

if (this . currentButton ! = 
null) 

this . currentButton . setUp ( ) ; 
this . currentButton = current- 
Eutton; 

this . currentButton . setDown ( ) ; 



} 
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* Liefert das aktuelle Tool public ToolButton getCurrent- 
zuriick. Button!) t 

* wird normalerweise von den return currentButton; 
Zeichenf lache auf geruf en. ) 



+ 



/ 20 

public Tool getCurrentTool ( ) { / 

return currentTool; * Liefert den Editor an die 

j Buttons weiter. 

*/ 

/ + + 25 public GraphEditor getEditor ( ) 

* Liefert den aktuellen But- { 

ton, damit der nachste return editor; 

* aktuelle Butten ihn zuruck- } 
setzen kann. 

*/ 30 } //Toolbar 
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Paten tanspruche 

1. Verfahren zur Bestimmung einer graphischen Struktur eines 
technischen Systems, 

a) bei dem aus einer Menge mehrerer unterschiedlicher Gra- 
phen-Struktur-Dateien eine Graphen-Struktur-Datei aus- 
gewahlt wird, wobei in einer Graphen-Struktur-Datei je- 
weils angegeben ist, welche Elemente zu deren Darstel- 
lung ausgewahlt werden konnen, urn das technische System 
in seiner Struktur graphisch zu beschreiben, 

b) bei dem Elemente ausgewahlt werden derart, daft mit den 
ausgewahlten Elementen das technische System beschrie- 
ben wird, und 

c) bei dem die Elemente von einem Editor-Programm darge- 
stellt werden, in welches die ausgewahlte Graphen- 
Struktur-Datei eingebunden worden ist, womit die gra- 
phische Struktur des technischen Systems bestimmt ist. 

2. Verfahren nach Anspruch 1, 

bei dem das technische System eine elektronische Schaltung 
ist . 

3. Verfahren nach Anspruch 2, 

bei dem das technische System eine technische Anlage ist. 

4. Verfahren nach einem der Anspriiche 1 bis 3, 

bei dem die Elemente Graphenelemente eines Graphen sind, die 
das technische System beschreiben. 

5. Verfahren nach einem der Anspriiche 1 bis 4, 

bei dem die bestimmte graphische Struktur des technischen Sy- 
stems auf vorgegebene Strukturregeln hin uberpruft wird. 

6. Anordnung zur Bestiimnung einer Graphen-Struktur , 

a) mit einem Speicher, in dem eine Menge mehrerer unter- 
schiedlicher Graphen-Struktur-Dateien gespeichert sind, 
wobei in einer Graphen-Struktur-Datei jeweils angegeben 
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ist, welche Elemente zu deren Darstellung ausgewahlt 
werden konnen, urn einen Graphen zu bilden, 

b) mit einer Auswahleinheit , mit der eine Graphen- 
Struktur-Datei aus der Menge der Graphen-Struktur- 
Dateien ausgewahlt werden kann, 

c) mit einem Prozessor, der derart eingerichtet ist, da£ 
ein Editor-Programm ausfuhrbar ist, mit welchem Editor 
Programm unter Verwendung einer aus der Menge der Gra- 
phen-Struktur-Dateien ausgewahlten Graphen-Struktur- 
Datei ein Graph mit Elementen der ausgewahlten Graphen 
Struktur-Datei bestimmt werden kann, womit die Graphen 
Struktur bestimmt ist, 

d) mit einer mit dem Editor-Programm gekoppelten Darstel- 
lungskomonente, mit der die bestimmte Graphen-Struktur 
dargestellt werden kann. 

7. Anordnung nach Anspruch 6, 

bei der mit dem Graphen eine Struktur eines technischen Sy- 
stems beschrieben wird. 

8. Anordnung nach Anspruch 7, 

bei der das technische System eine elektronische Schaltung 
ist . 

9. Anordnung nach Anspruch 7, 

bei der das technische System eine technische Anlage ist. 

10. Satz mehrerer Anordnungen zur Bestimmung einer Graphen- 
Struktur, 

a) mit einer ersten Anordnung, die einen Speicher auf- 
weist, in dem eine Menge mehrerer unterschiedlicher 
Graphen-Struktur-Dateien gespeichert sind, wobei in ei 
ner Graphen-Struktur-Datei jeweils angegeben ist, wel- 
che Elemente zu deren Darstellung ausgewahlt werden 
konnen, urn einen Graphen zu bilden, 

b) mit einer mit der ersten Anordnung gekoppelten zweiten 
Anordnung, die folgende Komponenten aufweist: 
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- eine Auswahleinheit , mit der eine Graphen-Struktur- 
Datei aus der Menge der Graphen-Struktur-Dateien ausge- 
wahlt werden kann, 

- ein Editor- Pro gramin, mit dem unter Verwendung einer 

5 aus der Menge der Graphen-Struktur-Dateien ausgewahlten 

Graphen-Struktur-Datei ein Graph mit Elementen der aus- 
gewahlten Graphen-Struktur-Datei bestimmt werden kann, 
womit die Graphen-Struktur bestimmt ist, 

- eine mit dem Editor-Programm gekoppelte Darstellungs- 
10 komonente, mit der die bestimmte Graphen-Struktur dar- 

gestellt werden kann. 

11. Satz von Anordnungen nach Anspruch 10, 

bei dem die erste Anordnung und die zweite Anordnung uber ein 
15 Kommunikationsnetz miteinander gekoppelt sind. 

12. Satz von Anordnungen nach Anspruch 10 oder 11, 

bei dem mit dem Graphen eine Struktur eines technischen Sy- 
stems beschrieben wird. 

20 

13. Anordnung nach Anspruch 12, 

bei dem das technische System eine elektronische Schaltung 
ist . 

25 14. Anordnung nach Anspruch 12, 

bei dem das technische System eine technische Anlage ist. 
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FIG 4 

Auswa hl einer Graphik-Struktur-Datei 

T 

Auswahl von Elementen, die gemaB der 
Graphik-Struktur-Datei zur Verfugung stehen 



401 



402 



Darstellung der Elemente 
von einem Editor-Programm 



403 
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FIG 5 
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